summaryrefslogtreecommitdiffstats
path: root/media/libdrm/mobile2/src/util/ustl-1.0
diff options
context:
space:
mode:
Diffstat (limited to 'media/libdrm/mobile2/src/util/ustl-1.0')
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/bktrace.cpp160
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/bktrace.h55
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/bsconf.h173
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/cmemlink.cpp110
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/cmemlink.h101
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/config.h296
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/fstream.cpp282
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/fstream.h78
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/memblock.cpp216
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/memblock.h74
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/memlink.cpp66
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/memlink.h115
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/mistream.cpp242
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/mistream.h293
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/mostream.h260
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ofstream.cpp163
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ofstream.h82
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/simd.h465
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/sistream.cpp237
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/sistream.h133
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/sostream.cpp193
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/sostream.h158
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/strmsize.h135
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ualgo.h677
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ualgobase.cpp293
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ualgobase.h334
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uassert.h21
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ubitset.cpp38
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ubitset.h131
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uctralgo.h482
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uctrstrm.h177
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uexception.cpp305
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uexception.h194
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ufunction.h480
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uheap.h153
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uios.h107
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uiosfunc.h103
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uiterator.h268
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ulaalgo.h223
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ulimits.h108
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ulist.h78
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/umap.h165
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/umatrix.h80
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/umemory.h199
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/umultimap.h121
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/umultiset.h106
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/unew.cpp33
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/unew.h52
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/unumeric.h160
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/upair.h63
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/upredalgo.h597
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uqueue.h71
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uset.h97
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uspecial.h267
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ustack.h46
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ustdxept.cpp72
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ustdxept.h143
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ustl.tbff84
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ustring.cpp425
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/ustring.h263
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/utf8.h200
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/utuple.h247
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/utypes.h69
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uutility.h387
-rw-r--r--media/libdrm/mobile2/src/util/ustl-1.0/uvector.h277
65 files changed, 0 insertions, 12483 deletions
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/bktrace.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/bktrace.cpp
deleted file mode 100644
index ae66463..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/bktrace.cpp
+++ /dev/null
@@ -1,160 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2006 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// bktrace.cc
-//
-
-#include "bktrace.h"
-#include "sostream.h"
-#include "mistream.h"
-#include "uassert.h"
-#if linux && __GNUC__ && !defined(HAVE_ANDROID_OS)
- #include <execinfo.h>
-#else
- static inline int backtrace (void**, int) { return (0); }
- static inline char** backtrace_symbols (void* const*, int) { return (NULL); }
-#endif
-#if __GNUC__ >= 3 && !PLATFORM_ANDROID
- #include <cxxabi.h>
-#endif
-
-namespace ustl {
-
-/// Default constructor. The backtrace is obtained here.
-CBacktrace::CBacktrace (void)
-: m_Symbols (NULL),
- m_nFrames (0),
- m_SymbolsSize (0)
-{
-#if !PLATFORM_ANDROID
- try {
-#endif
- m_nFrames = backtrace (VectorBlock (m_Addresses));
- GetSymbols();
-#if !PLATFORM_ANDROID
- } catch (...) {}
-#endif
-}
-
-/// Copy constructor.
-CBacktrace::CBacktrace (const CBacktrace& v)
-: m_Symbols (NULL),
- m_nFrames (0),
- m_SymbolsSize (0)
-{
- operator= (v);
-}
-
-/// Copy operator.
-const CBacktrace& CBacktrace::operator= (const CBacktrace& v)
-{
- memcpy (m_Addresses, v.m_Addresses, sizeof(m_Addresses));
- m_Symbols = strdup (v.m_Symbols);
- m_nFrames = v.m_nFrames;
- m_SymbolsSize = v.m_SymbolsSize;
- return (*this);
-}
-
-/// Converts a string returned by backtrace_symbols into readable form.
-static size_t ExtractAbiName (const char* isym, char* nmbuf)
-{
- // Prepare the demangled name, if possible
- size_t nmSize = 0;
- if (isym) {
- // Copy out the name; the strings are: "file(function+0x42) [0xAddress]"
- const char* mnStart = strchr (isym, '(');
- if (++mnStart == (const char*)(1))
- mnStart = isym;
- const char* mnEnd = strchr (isym, '+');
- const char* isymEnd = isym + strlen (isym);
- if (!mnEnd)
- mnEnd = isymEnd;
- nmSize = min (size_t (distance (mnStart, mnEnd)), 256U);
- memcpy (nmbuf, mnStart, nmSize);
- }
- nmbuf[nmSize] = 0;
- // Demangle
- demangle_type_name (nmbuf, 256U, &nmSize);
- return (nmSize);
-}
-
-/// Tries to get symbol information for the addresses.
-void CBacktrace::GetSymbols (void)
-{
- auto_ptr<char*> symbols (backtrace_symbols (m_Addresses, m_nFrames));
- if (!symbols.get())
- return;
- char nmbuf [256];
- size_t symSize = 1;
- for (uoff_t i = 0; i < m_nFrames; ++ i)
- symSize += ExtractAbiName (symbols.get()[i], nmbuf) + 1;
- if (!(m_Symbols = (char*) calloc (symSize, 1)))
- return;
- for (uoff_t i = 0; m_SymbolsSize < symSize - 1; ++ i) {
- size_t sz = ExtractAbiName (symbols.get()[i], nmbuf);
- memcpy (m_Symbols + m_SymbolsSize, nmbuf, sz);
- m_SymbolsSize += sz + 1;
- m_Symbols [m_SymbolsSize - 1] = '\n';
- }
-}
-
-/// Default destructor.
-CBacktrace::~CBacktrace (void)
-{
- free_nullok (m_Symbols);
-}
-
-#if SIZE_OF_LONG == 8
- #define ADDRESS_FMT "%16p "
-#else
- #define ADDRESS_FMT "%8p "
-#endif
-
-/// Prints the backtrace to \p os.
-void CBacktrace::text_write (ostringstream& os) const
-{
- const char *ss = m_Symbols, *se;
- for (uoff_t i = 0; i < m_nFrames; ++ i) {
- os.format (ADDRESS_FMT, m_Addresses[i]);
- se = strchr (ss, '\n') + 1;
- os.write (ss, distance (ss, se));
- ss = se;
- }
-}
-
-/// Reads the object from stream \p is.
-void CBacktrace::read (istream& is)
-{
- assert (is.aligned (alignof (m_Addresses[0])) && "Backtrace object contains pointers and must be void* aligned");
- is >> m_nFrames >> m_SymbolsSize;
- free_nullok (m_Symbols);
- m_Symbols = (char*) malloc (m_SymbolsSize + 1);
- is.read (m_Symbols, m_SymbolsSize);
- m_Symbols [m_SymbolsSize] = 0;
- is.align();
- is.read (m_Addresses, m_nFrames * sizeof(void*));
-}
-
-/// Writes the object to stream \p os.
-void CBacktrace::write (ostream& os) const
-{
- assert (os.aligned (alignof (m_Addresses[0])) && "Backtrace object contains pointers and must be void* aligned");
- os << m_nFrames << m_SymbolsSize;
- os.write (m_Symbols, m_SymbolsSize);
- os.align();
- os.write (m_Addresses, m_nFrames * sizeof(void*));
-}
-
-/// Returns the size of the written object.
-size_t CBacktrace::stream_size (void) const
-{
- return (Align (stream_size_of (m_nFrames) +
- stream_size_of (m_SymbolsSize) +
- m_nFrames * sizeof(void*) +
- m_SymbolsSize));
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/bktrace.h b/media/libdrm/mobile2/src/util/ustl-1.0/bktrace.h
deleted file mode 100644
index 7b8c0ea..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/bktrace.h
+++ /dev/null
@@ -1,55 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2006 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// bktrace.h
-//
-
-#ifndef BKTRACE_H_63ABB1E4388CEDD975DBE58B57DE474F
-#define BKTRACE_H_63ABB1E4388CEDD975DBE58B57DE474F
-
-#include "ulimits.h"
-
-namespace ustl {
-
-class ostringstream;
-class istream;
-class ostream;
-
-/// \class CBacktrace bktrace.h ustl.h
-///
-/// \brief Stores the backtrace from the point of construction.
-///
-/// The backtrace, or callstack, is the listing of functions called to
-/// reach the construction of this object. This is useful for debugging,
-/// to print the location of an error. To get meaningful output you'll
-/// need to use a debug build with symbols and with frame pointers. For
-/// GNU ld you will also need to link with the -rdynamic option to see
-/// actual function names instead of __gxx_personality0+0xF4800.
-///
-class CBacktrace {
-public:
- CBacktrace (void);
- CBacktrace (const CBacktrace& v);
- ~CBacktrace (void);
- const CBacktrace& operator= (const CBacktrace& v);
- void text_write (ostringstream& os) const;
- void read (istream& is);
- void write (ostream& os) const;
- size_t stream_size (void) const;
-private:
- void GetSymbols (void);
-private:
- void* m_Addresses [64]; ///< Addresses of each function on the stack.
- char* m_Symbols; ///< Symbols corresponding to each address.
- uint32_t m_nFrames; ///< Number of addresses in m_Addresses.
- uint32_t m_SymbolsSize; ///< Size of m_Symbols.
-};
-
-} // namespace ustl
-
-ALIGNOF(ustl::CBacktrace, sizeof(void*))
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/bsconf.h b/media/libdrm/mobile2/src/util/ustl-1.0/bsconf.h
deleted file mode 100644
index 79b4af1..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/bsconf.h
+++ /dev/null
@@ -1,173 +0,0 @@
-/* This file is part of bsconf - a configure replacement.
- *
- * This is the configuration file used by bsconf.c to specify information
- * specific to your project that it needs to substitute into files listed
- * in g_Files. Being a configuration file, this file can be used or
- * modified entirely without restriction. You should change all values
- * appropriately to the name of your project and its requirements. The
- * bsconf license does not apply to this file. It can and should be
- * treated as a template for the creation of your own configuration file.
- *
- * All substituted variable names are given without enclosing @@. For
- * example: "CC" will match "@CC@" in config.h.in and replace it with
- * "gcc" in config.h.
-*/
-
-#include "uassert.h"
-
-#define BSCONF_VERSION 0x03
-
-#define PACKAGE_NAME "ustl"
-#define LIB_MAJOR "1"
-#define LIB_MINOR "0"
-#define LIB_BUILD "0"
-
-#define PACKAGE_VERSION LIB_MAJOR "." LIB_MINOR
-#define PACKAGE_TARNAME PACKAGE_NAME
-#define PACKAGE_STRING PACKAGE_NAME " " PACKAGE_VERSION
-#define PACKAGE_BUGREPORT "Mike Sharov <msharov@users.sourceforge.net>"
-
-static cpchar_t g_Files [] = {
- "Config.mk",
- "config.h",
- "ustl.spec"
-};
-
-/* Values substitute @VARNAME@ */
-static cpchar_t g_EnvVars [] = {
- "CC",
- "LD",
- "CXX",
- "CPP",
- "HOME",
- "CXXFLAGS",
- "LDFLAGS",
- "CPPFLAGS",
- "LDFLAGS",
- "CFLAGS"
-};
-
-/* VARIABLE PROGRAM HOW TO CALL IF NOT FOUND */
-static cpchar_t g_ProgVars [] = {
- "CC", "gcc", "gcc", "@CC@",
- "CC", "cc", "cc", "gcc",
- "CXX", "g++", "g++", "@CXX@",
- "CXX", "c++", "c++", "g++",
- "LD", "ld", "ld", "ld",
- "AR", "ar", "ar", "echo",
- "RANLIB", "ranlib", "ranlib", "touch",
- "DOXYGEN", "doxygen", "doxygen", "echo",
- "INSTALL", "install", "install -c", "cp"
-};
-
-/* NAME IF NOT FOUND IF FOUND */
-static cpchar_t g_Headers [] = {
- "assert.h", "#undef HAVE_ASSERT_H", "#define HAVE_ASSERT_H 1",
- "ctype.h", "#undef HAVE_CTYPE_H", "#define HAVE_CTYPE_H 1",
- "errno.h", "#undef HAVE_ERRNO_H", "#define HAVE_ERRNO_H 1",
- "fcntl.h", "#undef HAVE_FCNTL_H", "#define HAVE_FCNTL_H 1",
- "float.h", "#undef HAVE_FLOAT_H", "#define HAVE_FLOAT_H 1",
- "inttypes.h", "#undef HAVE_INTTYPES_H", "#define HAVE_INTTYPES_H 1",
- "limits.h", "#undef HAVE_LIMITS_H", "#define HAVE_LIMITS_H 1",
- "locale.h", "#undef HAVE_LOCALE_H", "#define HAVE_LOCALE_H 1",
- "malloc.h", "#undef HAVE_MALLOC_H", "#define HAVE_MALLOC_H 1",
- "alloca.h", "#undef HAVE_ALLOCA_H", "#define HAVE_ALLOCA_H 1",
- "memory.h", "#undef HAVE_MEMORY_H", "#define HAVE_MEMORY_H 1",
- "signal.h", "#undef HAVE_SIGNAL_H", "#define HAVE_SIGNAL_H 1",
- "stdarg.h", "#undef HAVE_STDARG_H", "#define HAVE_STDARG_H 1",
- "stddef.h", "#undef HAVE_STDDEF_H", "#define HAVE_STDDEF_H 1",
- "stdint.h", "#undef HAVE_STDINT_H", "#define HAVE_STDINT_H 1",
- "stdio.h", "#undef HAVE_STDIO_H", "#define HAVE_STDIO_H 1",
- "stdlib.h", "#undef HAVE_STDLIB_H", "#define HAVE_STDLIB_H 1",
- "string.h", "#undef HAVE_STRING_H", "#define HAVE_STRING_H 1",
- "strings.h", "#undef HAVE_STRINGS_H", "#define HAVE_STRINGS_H 1",
- "sys/stat.h", "#undef HAVE_SYS_STAT_H", "#define HAVE_SYS_STAT_H 1",
- "sys/types.h", "#undef HAVE_SYS_TYPES_H", "#define HAVE_SYS_TYPES_H 1",
- "sys/wait.h", "#undef HAVE_SYS_WAIT_H", "#define HAVE_SYS_WAIT_H 1",
- "time.h", "#undef HAVE_TIME_H", "#define HAVE_TIME_H 1",
- "unistd.h", "#undef HAVE_UNISTD_H", "#define HAVE_UNISTD_H 1",
- "math.h", "#undef HAVE_MATH_H", "#define HAVE_MATH_H 1",
- "stdlib.h", "#undef HAVE_STDLIB_H", "#define HAVE_STDLIB_H 1"
-};
-
-/* NAME IF NOT FOUND IF FOUND */
-static cpchar_t g_Libs [] = {
- "supc++", "", "-lsupc++",
-#if __GNUC__ >= 4
- "gcc", "-lgcc_s", "-lgcc_s",
- "gcc_eh", "", "",
-#elif __GNUC__ >= 3
- "gcc", "-lgcc_s", "-lgcc",
- "gcc_eh", "-lgcc_s", "-lgcc_eh",
-#else
- "gcc", "", "-lgcc",
- "gcc_eh", "", "",
-#endif
- "SystemStubs", "", "-lSystemStubs", /* For MacOS 10.4+ */
- "c", "", "-lc"
-};
-
-/* NAME IF NOT FOUND IF FOUND */
-static cpchar_t g_Functions [] = {
- "atexit", "#undef HAVE_ATEXIT", "#define HAVE_ATEXIT 1",
- "malloc", "#undef HAVE_MALLOC\n", "#define HAVE_MALLOC 1\n",
- "memchr", "#undef HAVE_MEMCHR", "#define HAVE_MEMCHR 1",
- "memmove", "#undef HAVE_MEMMOVE", "#define HAVE_MEMMOVE 1",
- "memset", "#undef HAVE_MEMSET", "#define HAVE_MEMSET 1",
- "ptrdiff_t", "#undef HAVE_PTRDIFF_T", "#define HAVE_PTRDIFF_T 1",
- "strerror", "#undef HAVE_STRERROR", "#define HAVE_STRERROR 1",
- "strsignal", "#undef HAVE_STRSIGNAL", "#define HAVE_STRSIGNAL 1",
- "strtol", "#undef HAVE_STRTOL", "#define HAVE_STRTOL 1",
-#if __GNUC__ >= 3
- "round", "#undef HAVE_ROUND", "#define HAVE_ROUND 1",
-#endif
- "strrchr", "#undef HAVE_STRRCHR", "#define HAVE_STRRCHR 1",
- "__va_copy", "#undef HAVE_VA_COPY", "#define HAVE_VA_COPY 1"
-};
-
-/* NAME WITHOUT TEXT WITH TEXT */
-static cpchar_t g_Components [] = {
- "shared", "#BUILD_SHARED\t= 1", "BUILD_SHARED\t= 1 ",
- "static", "#BUILD_STATIC\t= 1", "BUILD_STATIC\t= 1 ",
- "debug", "#DEBUG\t\t= 1", "DEBUG\t\t= 1 ",
- "bounds", "#undef WANT_STREAM_BOUNDS_CHECKING", "#define WANT_STREAM_BOUNDS_CHECKING 1 ",
- "fastcopy", "#undef WANT_UNROLLED_COPY", "#define WANT_UNROLLED_COPY 1 ",
-#if __GNUC__ >= 3 && (__i386__ || __x86_64__) && !sun
- "mmx", "#undef WANT_MMX", "#define WANT_MMX 1 ",
-#endif
- "libstdc++", "#define WITHOUT_LIBSTDCPP 1", "#undef WITHOUT_LIBSTDCPP",
- "libstdc++", "NOLIBSTDCPP\t= -nodefaultlibs ", "#NOLIBSTDCPP\t= -nodefaultlibs"
-};
-
-/* Parallel to g_Components */
-static SComponentInfo g_ComponentInfos [VectorSize(g_Components) / 3] = {
- { 1, "Builds the shared library (if supported by the OS)" },
- { 0, "Builds the static library" },
- { 0, "Compiles the library with debugging information" },
- { 1, "Disable runtime bounds checking on stream reads/writes" },
- { 1, "Disable specializations for copy/fill" },
-#if __GNUC__ >= 3 && (__i386__ || __x86_64__) && !sun
- { 1, "Disable use of MMX/SSE/3dNow! instructions" },
-#endif
-#if __GNUC__ >= 3
- { 0, "Link with libstdc++" },
- { 0, "" }
-#else
- { 1, "" },
- { 1, "" }
-#endif
-};
-
-/* Substitutes names like @PACKAGE_NAME@ with the second field */
-static cpchar_t g_CustomVars [] = {
- "PACKAGE_NAME", PACKAGE_NAME,
- "PACKAGE_VERSION", PACKAGE_VERSION,
- "PACKAGE_TARNAME", PACKAGE_TARNAME,
- "PACKAGE_STRING", PACKAGE_STRING,
- "PACKAGE_BUGREPORT", PACKAGE_BUGREPORT,
- "LIBNAME", PACKAGE_NAME,
- "LIB_MAJOR", LIB_MAJOR,
- "LIB_MINOR", LIB_MINOR,
- "LIB_BUILD", LIB_BUILD
-};
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/cmemlink.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/cmemlink.cpp
deleted file mode 100644
index 7250e9f..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/cmemlink.cpp
+++ /dev/null
@@ -1,110 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// cmemlink.cc
-//
-// See cmemlink.h for documentation.
-//
-
-#include "cmemlink.h"
-#include "ofstream.h"
-#include "strmsize.h"
-#include "ualgo.h"
-#include "uassert.h"
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-#undef CPU_HAS_MMX
-#endif
-
-namespace ustl {
-
-/// \brief Attaches the object to pointer \p p of size \p n.
-///
-/// If \p p is NULL and \p n is non-zero, bad_alloc is thrown and current
-/// state remains unchanged.
-///
-void cmemlink::link (const void* p, size_type n)
-{
- if (!p && n)
-#if PLATFORM_ANDROID
- printf("bad alloc\n");
-#else /* !PLATFORM_ANDROID */
- throw bad_alloc (n);
-#endif
- unlink();
- relink (p, n);
-}
-
-/// Writes the object to stream \p os
-void cmemlink::write (ostream& os) const
-{
- const written_size_type sz (size());
- assert (sz == size() && "No support for writing memblocks larger than 4G");
- os << sz;
- os.write (cdata(), sz);
- os.align (alignof (sz));
-}
-
-/// Writes the object to stream \p os
-void cmemlink::text_write (ostringstream& os) const
-{
- os.write (begin(), readable_size());
-}
-
-/// Returns the number of bytes required to write this object to a stream.
-cmemlink::size_type cmemlink::stream_size (void) const
-{
- const written_size_type sz (size());
- return (Align (stream_size_of (sz) + sz, alignof(sz)));
-}
-
-/// Writes the data to file \p "filename".
-void cmemlink::write_file (const char* filename, int mode) const
-{
- fstream f;
- f.exceptions (fstream::allbadbits);
- f.open (filename, fstream::out | fstream::trunc, mode);
- f.write (cdata(), readable_size());
- f.close();
-}
-
-/// swaps the contents with \p l
-void cmemlink::swap (cmemlink& l)
-{
-#if CPU_HAS_MMX && SIZE_OF_POINTER == 4
- asm (
- "movq %0, %%mm0\n\t"
- "movq %2, %%mm1\n\t"
- "movq %%mm0, %2\n\t"
- "movq %%mm1, %0"
- : "=m"(m_Data), "=m"(m_Size), "=m"(l.m_Data), "=m"(l.m_Size)
- :
- : "mm0", "mm1", "st", "st(1)");
- simd::reset_mmx();
-#elif CPU_HAS_SSE && SIZE_OF_POINTER == 8
- asm (
- "movups %0, %%xmm0\n\t"
- "movups %2, %%xmm1\n\t"
- "movups %%xmm0, %2\n\t"
- "movups %%xmm1, %0"
- : "=m"(m_Data), "=m"(m_Size), "=m"(l.m_Data), "=m"(l.m_Size)
- :
- : "xmm0", "xmm1");
-#else
- ::ustl::swap (m_Data, l.m_Data);
- ::ustl::swap (m_Size, l.m_Size);
-#endif
-}
-
-/// Compares to memory block pointed by l. Size is compared first.
-bool cmemlink::operator== (const cmemlink& l) const
-{
- return (l.m_Size == m_Size &&
- (l.m_Data == m_Data || 0 == memcmp (l.m_Data, m_Data, m_Size)));
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/cmemlink.h b/media/libdrm/mobile2/src/util/ustl-1.0/cmemlink.h
deleted file mode 100644
index 46a9388..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/cmemlink.h
+++ /dev/null
@@ -1,101 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// cmemlink.h
-//
-
-#ifndef CMEMLINK_H_7CFAB32C5C6732ED29B34EF00EA40A12
-#define CMEMLINK_H_7CFAB32C5C6732ED29B34EF00EA40A12
-
-#include "ualgobase.h"
-
-/// The ustl namespace contains all ustl classes and algorithms.
-namespace ustl {
-
-class istream;
-class ostream;
-class ostringstream;
-
-/// \class cmemlink cmemlink.h ustl.h
-/// \ingroup MemoryManagement
-///
-/// \brief A read-only pointer to a sized block of memory.
-///
-/// Use this class the way you would a const pointer to an allocated unstructured block.
-/// The pointer and block size are available through member functions and cast operator.
-///
-/// Example usage:
-///
-/// \code
-/// void* p = malloc (46721);
-/// cmemlink a, b;
-/// a.link (p, 46721);
-/// assert (a.size() == 46721));
-/// b = a;
-/// assert (b.size() == 46721));
-/// assert (b.DataAt(34) == a.DataAt(34));
-/// assert (0 == memcmp (a, b, 12));
-/// \endcode
-///
-class cmemlink {
-public:
- typedef char value_type;
- typedef const value_type* pointer;
- typedef const value_type* const_pointer;
- typedef value_type reference;
- typedef value_type const_reference;
- typedef size_t size_type;
- typedef uint32_t written_size_type;
- typedef ptrdiff_t difference_type;
- typedef const_pointer const_iterator;
- typedef const_iterator iterator;
- typedef const cmemlink& rcself_t;
-public:
- inline cmemlink (void) : m_Data (NULL), m_Size (0) { }
- inline cmemlink (const void* p, size_type n) : m_Data (const_pointer(p)), m_Size (n) { assert (p || !n); }
- inline cmemlink (const cmemlink& l) : m_Data (l.m_Data), m_Size (l.m_Size) {}
- inline virtual ~cmemlink (void) {}
- void link (const void* p, size_type n);
- OVERLOAD_POINTER_AND_SIZE_T_V2(link, const void*)
- inline void link (const cmemlink& l) { link (l.begin(), l.size()); }
- inline void link (const void* first, const void* last) { link (first, distance (first, last)); }
- inline void relink (const void* p, size_type n);
- inline virtual void unlink (void) { m_Data = NULL; m_Size = 0; }
- inline rcself_t operator= (const cmemlink& l) { link (l); return (*this); }
- bool operator== (const cmemlink& l) const;
- void swap (cmemlink& l);
- inline size_type size (void) const { return (m_Size); }
- inline size_type max_size (void) const { return (size()); }
- inline size_type readable_size (void) const { return (size()); }
- inline bool empty (void) const { return (!size()); }
- inline const_pointer cdata (void) const { return (m_Data); }
- inline iterator begin (void) const { return (iterator (cdata())); }
- inline iterator iat (size_type i) const { assert (i <= size()); return (begin() + i); }
- inline iterator end (void) const { return (iat (size())); }
- inline void resize (size_type n) { m_Size = n; }
- inline void read (istream&) { assert (!"ustl::cmemlink is a read-only object."); }
- void write (ostream& os) const;
- size_type stream_size (void) const;
- void text_write (ostringstream& os) const;
- void write_file (const char* filename, int mode = 0644) const;
-private:
- const_pointer m_Data; ///< Pointer to the data block (const)
- size_type m_Size; ///< size of the data block
-};
-
-/// A fast alternative to link which can be used when relinking to the same block (i.e. when it is resized)
-inline void cmemlink::relink (const void* p, size_type n)
-{
- m_Data = reinterpret_cast<const_pointer>(p);
- m_Size = n;
-}
-
-/// Use with cmemlink-derived classes to link to a static array
-#define static_link(v) link (VectorBlock(v))
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/config.h b/media/libdrm/mobile2/src/util/ustl-1.0/config.h
deleted file mode 100644
index e6e4b7f..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/config.h
+++ /dev/null
@@ -1,296 +0,0 @@
-// config.h
-//
-// Autogenerated from config.h.in by bsconf.
-//
-
-#ifndef CONFIG_H_01E33670634DAAC779EE5FF41CCBB36F
-#define CONFIG_H_01E33670634DAAC779EE5FF41CCBB36F
-
-#include "uassert.h"
-
-#if PLATFORM_ANDROID
-
-#include <utils/Endian.h>
-
-// Byte order macros, converted in utypes.h
-#define USTL_LITTLE_ENDIAN __LITTLE_ENDIAN
-#define USTL_BIG_ENDIAN __BIG_ENDIAN
-#define USTL_BYTE_ORDER __BYTE_ORDER
-
-#if !defined NDEBUG
-#define NDEBUG
-#endif
-#else /* !PLATFORM_ANDROID */
-// Byte order macros, converted in utypes.h
-#define USTL_LITTLE_ENDIAN 4321
-#define USTL_BIG_ENDIAN 1234
-#define USTL_BYTE_ORDER USTL_LITTLE_ENDIAN
-#endif
-
-// Define to the one symbol short name of this package.
-#define USTL_NAME "ustl"
-// Define to the full name and version of this package.
-#define USTL_STRING "ustl 1.0"
-// Define to the version of this package.
-#define USTL_VERSION 0x100
-// Define to the address where bug reports for this package should be sent.
-#define USTL_BUGREPORT "Mike Sharov <msharov@users.sourceforge.net>"
-
-/// Define to 1 if you want stream operations to throw exceptions on
-/// insufficient data or insufficient space. All these errors should
-/// be preventable in output code; the input code should verify the
-/// data in a separate step. It slows down stream operations a lot,
-/// but it's your call. By default only debug builds throw.
-///
-#undef WANT_STREAM_BOUNDS_CHECKING
-
-#if !defined(WANT_STREAM_BOUNDS_CHECKING) && !defined(NDEBUG)
- #define WANT_STREAM_BOUNDS_CHECKING 1
-#endif
-
-/// Define to 1 if you want to build without libstdc++
-#define WITHOUT_LIBSTDCPP 1
-
-/// Define GNU extensions if unavailable.
-#ifndef __GNUC__
- /// GCC (and some other compilers) define '__attribute__'; ustl is using this
- /// macro to alert the compiler to flag inconsistencies in printf/scanf-like
- /// function calls. Just in case '__attribute__' isn't defined, make a dummy.
- ///
- #ifndef __attribute__
- #define __attribute__(p)
- #endif
-#endif
-#if defined(__GNUC__) && __GNUC__ >= 4
- #define DLL_EXPORT __attribute__((visibility("default")))
- #define DLL_LOCAL __attribute__((visibility("hidden")))
-#else
- #define DLL_EXPORT
- #define DLL_LOCAL
-#endif
-#if defined(__GNUC__) && __GNUC__ >= 3 && __i386__
- /// GCC 3+ supports the prefetch directive, which some CPUs use to improve caching
- #define prefetch(p,rw,loc) __builtin_prefetch(p,rw,loc)
-#else
- #define prefetch(p,rw,loc)
-#endif
-#if !defined(__GNUC__) || __GNUC__ < 3
- /// __alignof__ returns the recommended alignment for the type
- #define __alignof__(v) min(sizeof(v), sizeof(void*))
-#endif
-
-/// Define to 1 if you have the `atexit' function.
-#define HAVE_ATEXIT 1
-
-/// Define to 1 if you have the <assert.h> header file.
-#define HAVE_ASSERT_H 1
-
-/// Define to 1 if you have the <ctype.h> header file.
-#define HAVE_CTYPE_H 1
-
-/// Define to 1 if you have the <errno.h> header file.
-#define HAVE_ERRNO_H 1
-
-/// Define to 1 if you have the <fcntl.h> header file.
-#define HAVE_FCNTL_H 1
-
-/// Define to 1 if you have the <float.h> header file.
-#define HAVE_FLOAT_H 1
-
-/// Define to 1 if you have the <inttypes.h> header file.
-#define HAVE_INTTYPES_H 1
-
-/// Define to 1 if you have the <limits.h> header file.
-#define HAVE_LIMITS_H 1
-
-/// Define to 1 if you have the <locale.h> header file.
-#define HAVE_LOCALE_H 1
-
-/// Define to 1 if your system has a working `malloc' function.
-#define HAVE_MALLOC 1
-
-// Define to 1 if you have the <malloc.h> header file.
-#undef HAVE_MALLOC_H
-
-// Define to 1 if you have the <alloca.h> header file.
-#define HAVE_ALLOCA_H 1
-
-// Define to 1 if you have the `memchr' function.
-#define HAVE_MEMCHR 1
-
-// Define to 1 if you have the `memmove' function.
-#define HAVE_MEMMOVE 1
-
-// Define to 1 if you have the <memory.h> header file.
-#define HAVE_MEMORY_H 1
-
-// Define to 1 if you have the `memset' function.
-#define HAVE_MEMSET 1
-
-// Define to 1 if the system has the type `ptrdiff_t'.
-#define HAVE_PTRDIFF_T 1
-
-// Define to 1 if you have the <signal.h> header file.
-#define HAVE_SIGNAL_H 1
-
-// Define to 1 if you have the __va_copy function
-#define HAVE_VA_COPY 1
-
-// Define to 1 if `stat' has the bug that it succeeds when given the
-// zero-length file name argument.
-/* #undef HAVE_STAT_EMPTY_STRING_BUG */
-
-// Define to 1 if you have the <stdarg.h> header file.
-#define HAVE_STDARG_H 1
-
-// Define to 1 if you have the <stddef.h> header file.
-#define HAVE_STDDEF_H 1
-
-// Define to 1 if you have the <stdint.h> header file.
-#define HAVE_STDINT_H 1
-
-// Define to 1 if you have the <stdio.h> header file.
-#define HAVE_STDIO_H 1
-
-// Define to 1 if you have the <stdlib.h> header file.
-#define HAVE_STDLIB_H 1
-
-// Define to 1 if you have the `strerror' function.
-#define HAVE_STRERROR 1
-
-// Define to 1 if you have the <strings.h> header file.
-#define HAVE_STRINGS_H 1
-
-// Define to 1 if you have the <string.h> header file.
-#define HAVE_STRING_H 1
-
-// Define to 1 if you have the `strrchr' function.
-#define HAVE_STRRCHR 1
-
-// Define to 1 if you have the `strsignal' function.
-#undef HAVE_STRSIGNAL
-
-// Define to 1 if you have the `strtol' function.
-#define HAVE_STRTOL 1
-
-// Define to 1 if you have the <sys/stat.h> header file.
-#define HAVE_SYS_STAT_H 1
-
-// Define to 1 if you have the <sys/types.h> header file.
-#define HAVE_SYS_TYPES_H 1
-
-// Define to 1 if you have <sys/wait.h> that is POSIX.1 compatible.
-#define HAVE_SYS_WAIT_H 1
-
-// Define to 1 if you have the <time.h> header file.
-#define HAVE_TIME_H 1
-
-// Define to 1 if you have the <unistd.h> header file.
-#define HAVE_UNISTD_H 1
-
-// Define to 1 if you have the <math.h> header file.
-#define HAVE_MATH_H 1
-
-// Define to 1 if you have the rintf function. Will use rint otherwise.
-#undef HAVE_RINTF
-
-// STDC_HEADERS is defined to 1 on sane systems.
-#if defined(HAVE_ASSERT_H) && defined(HAVE_CTYPE_H) &&\
- defined(HAVE_ERRNO_H) && defined(HAVE_FLOAT_H) &&\
- defined(HAVE_LIMITS_H) && defined(HAVE_LOCALE_H) &&\
- defined(HAVE_MATH_H) && defined(HAVE_SIGNAL_H) &&\
- defined(HAVE_STDARG_H) && defined(HAVE_STDDEF_H) &&\
- defined(HAVE_STDIO_H) && defined(HAVE_STDLIB_H) &&\
- defined(HAVE_STRING_H) && defined(HAVE_TIME_H)
-#define STDC_HEADERS 1
-#endif
-
-// STDC_HEADERS is defined to 1 on unix systems.
-#if defined(HAVE_FCNTL_H) && defined(HAVE_SYS_STAT_H) && defined(HAVE_UNISTD_H)
-#define STDUNIX_HEADERS 1
-#endif
-
-// Define to 1 if `lstat' dereferences a symlink specified with a trailing slash.
-#define LSTAT_FOLLOWS_SLASHED_SYMLINK 1
-
-// Define to 1 if your compiler treats char as a separate type along with
-// signed char and unsigned char. This will create overloads for char.
-#define HAVE_THREE_CHAR_TYPES 1
-
-// Define as the return type of signal handlers (`int' or `void').
-#define RETSIGTYPE void
-
-// Define to 1 if you have 64 bit types available
-#define HAVE_INT64_T 1
-
-// Define to 1 if you have the long long type
-#undef HAVE_LONG_LONG
-
-// Define to 1 if you want unrolled specializations for fill and copy
-#define WANT_UNROLLED_COPY 1
-
-// Define to 1 if you want to use MMX/SSE/3dNow! processor instructions
-#undef WANT_MMX
-
-// Define to byte sizes of types
-#define SIZE_OF_CHAR 1
-#define SIZE_OF_SHORT 2
-#define SIZE_OF_INT 4
-#define SIZE_OF_LONG 4
-#define SIZE_OF_LONG_LONG 8
-#define SIZE_OF_POINTER 4
-#define SIZE_OF_SIZE_T 4
-#define SIZE_OF_BOOL SIZE_OF_LONG
-#if SIZE_OF_SIZE_T == SIZE_OF_LONG
-#define SIZE_T_IS_LONG 1
-#else
-#define SIZE_T_IS_LONG 0
-#endif
-
-// Extended CPU capabilities
-#undef CPU_HAS_FPU
-#undef CPU_HAS_EXT_DEBUG
-#undef CPU_HAS_TIMESTAMPC
-#undef CPU_HAS_MSR
-#undef CPU_HAS_CMPXCHG8
-#undef CPU_HAS_APIC
-#undef CPU_HAS_SYSCALL
-#undef CPU_HAS_MTRR
-#undef CPU_HAS_CMOV
-#undef CPU_HAS_FCMOV
-#if WANT_MMX
-#undef CPU_HAS_MMX
-#undef CPU_HAS_FXSAVE
-#undef CPU_HAS_SSE
-#undef CPU_HAS_SSE2
-#undef CPU_HAS_SSE3
-#undef CPU_HAS_EXT_3DNOW
-#undef CPU_HAS_3DNOW
-#endif
-
-// GCC vector extensions
-#if defined(CPU_HAS_MMX) || defined(CPU_HAS_SSE)
- #define HAVE_VECTOR_EXTENSIONS 1
-#endif
-
-#if CPU_HAS_SSE && defined(__GNUC__)
- #define __sse_align __attribute__((aligned(16)))
-#else
- #define __sse_align
-#endif
-
-// Define to empty if `const' does not conform to ANSI C.
-/* #define const */
-
-// Define as `__inline' if that's what the C compiler calls it, or to nothing
-// if it is not supported.
-/* #define inline __inline */
-
-// Define to `long' if <sys/types.h> does not define.
-/* typedef long off_t; */
-
-// Define to `unsigned' if <sys/types.h> does not define.
-/* typedef long size_t; */
-
-#endif // CONFIG_H_01E33670634DAAC779EE5FF41CCBB36F
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/fstream.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/fstream.cpp
deleted file mode 100644
index 06b9691..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/fstream.cpp
+++ /dev/null
@@ -1,282 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// file.cc
-//
-
-#include "fstream.h"
-#include "uassert.h"
-#include "uexception.h"
-#include "uutility.h"
-
-#include <fcntl.h>
-#include <unistd.h>
-#include <errno.h>
-#include <sys/stat.h>
-#include <sys/mman.h>
-#include <sys/ioctl.h>
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-#endif
-
-namespace ustl {
-
-/// Default constructor.
-fstream::fstream (void)
-: ios_base (),
- m_fd (-1),
- m_Filename ()
-{
-}
-
-/// Opens \p filename in \p mode.
-fstream::fstream (const char* filename, openmode mode)
-: ios_base (),
- m_fd (-1),
- m_Filename ()
-{
- open (filename, mode);
-}
-
-/// Attaches to \p nfd of \p filename.
-fstream::fstream (int nfd, const char* filename)
-: ios_base (),
- m_fd (-1),
- m_Filename ()
-{
- attach (nfd, filename);
-}
-
-/// Destructor. Closes if still open, but without throwing.
-fstream::~fstream (void) throw()
-{
- clear (goodbit);
- exceptions (goodbit);
- close();
- assert (!(rdstate() & badbit) && "close failed in the destructor! This may lead to loss of user data. Please call close() manually and either enable exceptions or check the badbit.");
-}
-
-/// Sets state \p s and throws depending on the exception setting.
-void fstream::set_and_throw (iostate s, const char* op)
-{
- if (ios_base::set_and_throw (s))
-#if PLATFORM_ANDROID
- printf("file_exception\n");
-#else /* !PLATFORM_ANDROID */
- throw file_exception (op, name());
-#endif
-}
-
-/// Attaches to the given \p nfd.
-void fstream::attach (int nfd, const char* filename)
-{
- assert (filename && "Don't do that");
- clear (goodbit);
- if (nfd < 0 && ios_base::set_and_throw (badbit))
-#if PLATFORM_ANDROID
- printf("file exception\n");
-#else /* !PLATFORM_ANDROID */
- throw file_exception ("open", filename);
-#endif
- close();
- m_fd = nfd;
- m_Filename = filename;
-}
-
-/// Detaches from the current fd.
-void fstream::detach (void)
-{
- m_fd = -1;
- m_Filename.clear();
-}
-
-/// Converts openmode bits into libc open flags.
-/*static*/ int fstream::om_to_flags (openmode m)
-{
- static const int s_OMFlags [nombits] = {
- 0, // in
- O_CREAT, // out
- O_APPEND, // app
- O_APPEND, // ate
- 0, // binary
- O_TRUNC, // trunc
- O_NONBLOCK, // nonblock
- 0, // nocreate
- O_NOCTTY // noctty
- };
- int flags = (m - 1) & O_ACCMODE; // in and out
- for (uoff_t i = 0; i < VectorSize(s_OMFlags); ++ i)
- if (m & (1 << i))
- flags |= s_OMFlags[i];
- if (m & nocreate)
- flags &= ~O_CREAT;
- return (flags);
-}
-
-/// \brief Opens \p filename in the given mode.
-/// \warning The string at \p filename must exist until the object is closed.
-void fstream::open (const char* filename, openmode mode, mode_t perms)
-{
- int nfd = ::open (filename, om_to_flags(mode), perms);
- attach (nfd, filename);
-}
-
-/// Closes the file and throws on error.
-void fstream::close (void)
-{
- if (m_fd >= 0 && ::close(m_fd))
- set_and_throw (badbit | failbit, "close");
- detach();
-}
-
-/// Moves the current file position to \p n.
-off_t fstream::seek (off_t n, seekdir whence)
-{
- off_t p = lseek (m_fd, n, whence);
- if (p < 0)
- set_and_throw (failbit, "seek");
- return (p);
-}
-
-/// Returns the current file position.
-off_t fstream::pos (void) const
-{
- return (lseek (m_fd, 0, SEEK_CUR));
-}
-
-/// Reads \p n bytes into \p p.
-off_t fstream::read (void* p, off_t n)
-{
- off_t br (0);
- while (br < n && good())
- br += readsome (advance (p, br), n - br);
- return (br);
-}
-
-/// Reads at most \p n bytes into \p p, stopping when it feels like it.
-off_t fstream::readsome (void* p, off_t n)
-{
- ssize_t brn;
- do { brn = ::read (m_fd, p, n); } while (brn < 0 && errno == EINTR);
- if (brn > 0)
- return (brn);
- if (brn < 0 && errno != EAGAIN)
- set_and_throw (failbit, "read");
- if (!brn && ios_base::set_and_throw (eofbit | failbit))
-#if PLATFORM_ANDROID
- printf("stream_bounds_exception\n");
-#else /* !PLATFORM_ANDROID */
- throw stream_bounds_exception ("read", name(), pos(), n, 0);
-#endif
- return (0);
-}
-
-/// Writes \p n bytes from \p p.
-off_t fstream::write (const void* p, off_t n)
-{
- off_t btw (n);
- while (btw) {
- const off_t bw (n - btw);
- ssize_t bwn = ::write (m_fd, advance(p,bw), btw);
- if (bwn > 0)
- btw -= bwn;
- else if (!bwn) {
- if (ios_base::set_and_throw (eofbit | failbit))
-#if PLATFORM_ANDROID
- printf("stream_bounds_exception\n");
-#else /* !PLATFORM_ANDROID */
- throw stream_bounds_exception ("write", name(), pos() - bw, n, bw);
-#endif
- break;
- } else if (errno != EINTR) {
- if (errno != EAGAIN)
- set_and_throw (failbit, "write");
- break;
- }
- }
- return (n - btw);
-}
-
-/// Returns the file size.
-off_t fstream::size (void) const
-{
- struct stat st;
- st.st_size = 0;
- stat (st);
- return (st.st_size);
-}
-
-/// Synchronizes the file's data and status with the disk.
-void fstream::sync (void)
-{
- if (fsync (m_fd))
- set_and_throw (failbit, "sync");
-}
-
-/// Get the stat structure.
-void fstream::stat (struct stat& rs) const
-{
- if (fstat (m_fd, &rs))
-#if PLATFORM_ANDROID
- printf("file_exception\n");
-#else
- throw file_exception ("stat", name());
-#endif
-}
-
-/// Calls the given ioctl. Use IOCTLID macro to pass in both \p name and \p request.
-int fstream::ioctl (const char* rname, int request, long argument)
-{
- int rv = ::ioctl (m_fd, request, argument);
- if (rv < 0)
- set_and_throw (failbit, rname);
- return (rv);
-}
-
-/// Calls the given fcntl. Use FCNTLID macro to pass in both \p name and \p request.
-int fstream::fcntl (const char* rname, int request, long argument)
-{
- int rv = ::fcntl (m_fd, request, argument);
- if (rv < 0)
- set_and_throw (failbit, rname);
- return (rv);
-}
-
-/// Memory-maps the file and returns a link to it.
-memlink fstream::mmap (off_t n, off_t offset)
-{
- void* result = ::mmap (NULL, n, PROT_READ | PROT_WRITE, MAP_SHARED, m_fd, offset);
- if (result == MAP_FAILED)
- set_and_throw (failbit, "mmap");
- return (memlink (result, n));
-}
-
-/// Unmaps a memory-mapped area.
-void fstream::munmap (memlink& l)
-{
- if (::munmap (l.data(), l.size()))
- set_and_throw (failbit, "munmap");
- l.unlink();
-}
-
-/// Synchronizes a memory-mapped area.
-void fstream::msync (memlink& l)
-{
- if (::msync (l.data(), l.size(), MS_ASYNC | MS_INVALIDATE))
- set_and_throw (failbit, "msync");
-}
-
-void fstream::set_nonblock (bool v)
-{
- int curf = fcntl (FCNTLID (F_GETFL));
- if (curf < 0) return;
- if (v) curf |= O_NONBLOCK;
- else curf &= ~O_NONBLOCK;
- fcntl (FCNTLID (F_SETFL), curf);
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/fstream.h b/media/libdrm/mobile2/src/util/ustl-1.0/fstream.h
deleted file mode 100644
index cf60bbd..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/fstream.h
+++ /dev/null
@@ -1,78 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// fstream.h
-//
-
-#ifndef FSTREAM_H_056E10F70EAD416443E3B36A2D6B5FA3
-#define FSTREAM_H_056E10F70EAD416443E3B36A2D6B5FA3
-
-#include "uios.h"
-#include "ustring.h"
-
-struct stat;
-
-namespace ustl {
-
-/// \class fstream fstream.h ustl.h
-///
-/// \brief Implements file operations.
-///
-/// This is not implemented as a stream, but rather as a base for one. You
-/// should use ifstream or ofstream if you want flow operators. Otherwise
-/// this only implements functions for binary i/o.
-///
-class fstream : public ios_base {
-public:
- fstream (void);
- explicit fstream (const char* filename, openmode mode = in | out);
- explicit fstream (int nfd, const char* filename = string::empty_string);
- ~fstream (void) throw();
- void open (const char* filename, openmode mode, mode_t perms = 0644);
- void attach (int nfd, const char* filename = string::empty_string);
- void detach (void);
- void close (void);
- void sync (void);
- off_t read (void* p, off_t n);
- off_t readsome (void* p, off_t n);
- off_t write (const void* p, off_t n);
- off_t size (void) const;
- off_t seek (off_t n, seekdir whence = beg);
- off_t pos (void) const;
- void stat (struct stat& rs) const;
- int ioctl (const char* rname, int request, long argument = 0);
- inline int ioctl (const char* rname, int request, int argument) { return (fstream::ioctl (rname, request, long(argument))); }
- inline int ioctl (const char* rname, int request, void* argument) { return (fstream::ioctl (rname, request, intptr_t(argument))); }
- int fcntl (const char* rname, int request, long argument = 0);
- inline int fcntl (const char* rname, int request, int argument) { return (fstream::fcntl (rname, request, long(argument))); }
- inline int fcntl (const char* rname, int request, void* argument) { return (fstream::fcntl (rname, request, intptr_t(argument))); }
- memlink mmap (off_t n, off_t offset = 0);
- void munmap (memlink& l);
- void msync (memlink& l);
- void set_nonblock (bool v = true);
- inline int fd (void) const { return (m_fd); }
- inline bool is_open (void) const { return (fd() >= 0); }
- inline off_t tellg (void) const { return (pos()); }
- inline off_t tellp (void) const { return (pos()); }
- inline void seekg (off_t n, seekdir whence = beg) { seek (n, whence); }
- inline void seekp (off_t n, seekdir whence = beg) { seek (n, whence); }
- inline void flush (void) { sync(); }
- inline const string& name (void) const { return (m_Filename); }
-private:
- DLL_LOCAL static int om_to_flags (openmode m);
- DLL_LOCAL void set_and_throw (iostate s, const char* op);
-private:
- int m_fd; ///< Currently open file descriptor.
- string m_Filename; ///< Currently open filename.
-};
-
-/// Argument macro for fstream::ioctl. Use like fs.ioctl (IOCTLID (TCGETS), &ts).
-#define IOCTLID(r) "ioctl("#r")", r
-#define FCNTLID(r) "fcntl("#r")", r
-
-}
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/memblock.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/memblock.cpp
deleted file mode 100644
index 721433e..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/memblock.cpp
+++ /dev/null
@@ -1,216 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// memblock.cc
-//
-// Allocated memory block.
-//
-
-#include "fstream.h"
-#include "mistream.h"
-#include "memblock.h"
-#include "ualgo.h"
-#include "uassert.h"
-#include "umemory.h"
-
-#include <errno.h>
-
-namespace ustl {
-
-/// Allocates 0 bytes for the internal block.
-memblock::memblock (void)
-: memlink (),
- m_Capacity (0)
-{
-}
-
-/// Allocates \p n bytes for the internal block.
-memblock::memblock (size_type n)
-: memlink (),
- m_Capacity (0)
-{
- resize (n);
-}
-
-/// links to \p p, \p n. Data can not be modified and will not be freed.
-memblock::memblock (const void* p, size_type n)
-: memlink (),
- m_Capacity (0)
-{
- assign (p, n);
-}
-
-/// Links to what \p b is linked to.
-memblock::memblock (const cmemlink& b)
-: memlink (),
- m_Capacity (0)
-{
- assign (b);
-}
-
-/// Links to what \p b is linked to.
-memblock::memblock (const memlink& b)
-: memlink (),
- m_Capacity (0)
-{
- assign (b);
-}
-
-/// Links to what \p b is linked to.
-memblock::memblock (const memblock& b)
-: memlink (),
- m_Capacity (0)
-{
- assign (b);
-}
-
-/// Frees internal data, if appropriate
-/// Only if the block was allocated using resize, or linked to using Manage,
-/// will it be freed. Also, Derived classes should call DestructBlock from
-/// their destructor, because upstream virtual functions are unavailable at
-/// this point and will not be called automatically.
-///
-memblock::~memblock (void)
-{
- if (!is_linked())
- deallocate();
-}
-
-/// resizes the block to \p newSize bytes, reallocating if necessary.
-void memblock::resize (size_type newSize, bool bExact)
-{
- if (m_Capacity < newSize + minimumFreeCapacity())
- reserve (newSize, bExact);
- memlink::resize (newSize);
-}
-
-/// Frees internal data.
-void memblock::deallocate (void) throw()
-{
- if (m_Capacity) {
- assert (cdata() && "Internal error: space allocated, but the pointer is NULL");
- assert (data() && "Internal error: read-only block is marked as allocated space");
- free (data());
- }
- unlink();
-}
-
-/// Assumes control of the memory block \p p of size \p n.
-/// The block assigned using this function will be freed in the destructor.
-void memblock::manage (void* p, size_type n)
-{
- assert (p || !n);
- assert (!m_Capacity && "Already managing something. deallocate or unlink first.");
- link (p, n);
- m_Capacity = n;
-}
-
-/// "Instantiate" a linked block by allocating and copying the linked data.
-void memblock::copy_link (void)
-{
- const cmemlink l (*this);
- if (is_linked())
- unlink();
- assign (l);
-}
-
-/// Copies data from \p p, \p n.
-void memblock::assign (const void* p, size_type n)
-{
- assert ((p != (const void*) cdata() || size() == n) && "Self-assignment can not resize");
- resize (n);
- copy (p, n);
-}
-
-/// \brief Reallocates internal block to hold at least \p newSize bytes.
-///
-/// Additional memory may be allocated, but for efficiency it is a very
-/// good idea to call reserve before doing byte-by-byte edit operations.
-/// The block size as returned by size() is not altered. reserve will not
-/// reduce allocated memory. If you think you are wasting space, call
-/// deallocate and start over. To avoid wasting space, use the block for
-/// only one purpose, and try to get that purpose to use similar amounts
-/// of memory on each iteration.
-///
-void memblock::reserve (size_type newSize, bool bExact)
-{
- if ((newSize += minimumFreeCapacity()) <= m_Capacity)
- return;
- void* oldBlock (is_linked() ? NULL : data());
- if (!bExact)
- newSize = Align (newSize, c_PageSize);
- pointer newBlock = (pointer) realloc (oldBlock, newSize);
- if (!newBlock)
-#if PLATFORM_ANDROID
- printf("bad_alloc\n");
-#else
- throw bad_alloc (newSize);
-#endif
- if (!oldBlock && cdata())
- copy_n (cdata(), min (size() + 1, newSize), newBlock);
- link (newBlock, size());
- m_Capacity = newSize;
-}
-
-/// Swaps the contents with \p l
-void memblock::swap (memblock& l)
-{
- memlink::swap (l);
- ::ustl::swap (m_Capacity, l.m_Capacity);
-}
-
-/// Shifts the data in the linked block from \p start to \p start + \p n.
-memblock::iterator memblock::insert (iterator start, size_type n)
-{
- const uoff_t ip = start - begin();
- assert (ip <= size());
- resize (size() + n, false);
- memlink::insert (iat(ip), n);
- return (iat (ip));
-}
-
-/// Shifts the data in the linked block from \p start + \p n to \p start.
-memblock::iterator memblock::erase (iterator start, size_type n)
-{
- const uoff_t ep = start - begin();
- assert (ep + n <= size());
- memlink::erase (start, n);
- memlink::resize (size() - n);
- return (iat (ep));
-}
-
-/// Unlinks object.
-void memblock::unlink (void)
-{
- memlink::unlink();
- m_Capacity = 0;
-}
-
-/// Reads the object from stream \p s
-void memblock::read (istream& is)
-{
- written_size_type n;
- is >> n;
- is.verify_remaining ("read", "ustl::memblock", n);
- resize (n);
- is.read (data(), writable_size());
- is.align (alignof (n));
-}
-
-/// Reads the entire file \p "filename".
-void memblock::read_file (const char* filename)
-{
- fstream f;
- f.exceptions (fstream::allbadbits);
- f.open (filename, fstream::in);
- const off_t fsize (f.size());
- reserve (fsize);
- f.read (data(), fsize);
- f.close();
- resize (fsize);
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/memblock.h b/media/libdrm/mobile2/src/util/ustl-1.0/memblock.h
deleted file mode 100644
index d85ea0e..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/memblock.h
+++ /dev/null
@@ -1,74 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// memblock.h
-//
-
-#ifndef MEMBLOCK_H_7ED63A891164CC43578E63664D52A196
-#define MEMBLOCK_H_7ED63A891164CC43578E63664D52A196
-
-#include "memlink.h"
-
-namespace ustl {
-
-/// \class memblock memblock.h ustl.h
-/// \ingroup MemoryManagement
-///
-/// \brief Allocated memory block.
-///
-/// Adds memory management capabilities to memlink. Uses malloc and realloc to
-/// maintain the internal pointer, but only if allocated using members of this class,
-/// or if linked to using the Manage() member function. Managed memory is automatically
-/// freed in the destructor.
-///
-class memblock : public memlink {
-public:
- static const size_type c_PageSize = 64; ///< The default minimum allocation unit.
-public:
- memblock (void);
- memblock (const void* p, size_type n);
- explicit memblock (size_type n);
- explicit memblock (const cmemlink& b);
- explicit memblock (const memlink& b);
- memblock (const memblock& b);
- virtual ~memblock (void);
- virtual void unlink (void);
- inline void assign (const cmemlink& l) { assign (l.cdata(), l.readable_size()); }
- inline const memblock& operator= (const cmemlink& l) { assign (l); return (*this); }
- inline const memblock& operator= (const memlink& l) { assign (l); return (*this); }
- inline const memblock& operator= (const memblock& l) { assign (l); return (*this); }
- void assign (const void* p, size_type n);
- void swap (memblock& l);
- void reserve (size_type newSize, bool bExact = true);
- void resize (size_type newSize, bool bExact = true);
- iterator insert (iterator start, size_type size);
- iterator erase (iterator start, size_type size);
- inline void clear (void) { resize (0); }
- inline bool is_linked (void) const { return (!m_Capacity && cdata()); }
- inline size_type max_size (void) const { return (is_linked() ? memlink::max_size() : SIZE_MAX); }
- inline size_type capacity (void) const { return (m_Capacity); }
- inline void manage (memlink& l) { manage (l.begin(), l.size()); }
- void deallocate (void) throw();
- void manage (void* p, size_type n);
- void copy_link (void);
- void read (istream& is);
- void read_file (const char* filename);
-protected:
- inline virtual size_type minimumFreeCapacity (void) const { return (0); }
-private:
- size_type m_Capacity; ///< Number of bytes allocated by Resize.
-};
-
-/// Reads object \p l from stream \p is
-inline istream& operator>> (istream& is, memblock& l)
-{
- l.read (is);
- return (is);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/memlink.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/memlink.cpp
deleted file mode 100644
index bed6601..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/memlink.cpp
+++ /dev/null
@@ -1,66 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// memlink.cc
-//
-// A pointer to a sized block of memory.
-//
-
-#include "mistream.h"
-#include "uassert.h"
-#include "ustdxept.h"
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-#endif
-
-namespace ustl {
-
-/// Reads the object from stream \p s
-void memlink::read (istream& is)
-{
- written_size_type n;
- is >> n;
- is.verify_remaining ("read", "ustl::memlink", n);
- if (n > size())
-#if PLATFORM_ANDROID
- printf("length error\n");
-#else
- throw length_error ("memlink can not increase the size of the linked storage for reading");
-#endif
- resize (n);
- is.read (data(), n);
- is.align (alignof (n));
-}
-
-/// Copies data from \p p, \p n to the linked block starting at \p start.
-void memlink::copy (iterator start, const void* p, size_type n)
-{
- assert (data() || !n);
- assert (p || !n);
- assert (start >= begin() && start + n <= end());
- if (p)
- copy_n (const_iterator(p), n, start);
-}
-
-/// Fills the linked block with the given pattern.
-/// \arg start Offset at which to start filling the linked block
-/// \arg p Pointer to the pattern.
-/// \arg elSize Size of the pattern.
-/// \arg elCount Number of times to write the pattern.
-/// Total number of bytes written is \p elSize * \p elCount.
-///
-void memlink::fill (iterator start, const void* p, size_type elSize, size_type elCount)
-{
- assert (data() || !elCount || !elSize);
- assert (start >= begin() && start + elSize * elCount <= end());
- if (elSize == 1)
- fill_n (start, elCount, *reinterpret_cast<const uint8_t*>(p));
- else while (elCount--)
- start = copy_n (const_iterator(p), elSize, start);
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/memlink.h b/media/libdrm/mobile2/src/util/ustl-1.0/memlink.h
deleted file mode 100644
index 25d9928..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/memlink.h
+++ /dev/null
@@ -1,115 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// memlink.h
-
-#ifndef MEMLINK_H_798D25827C8E322D2D7E734B169FF5FC
-#define MEMLINK_H_798D25827C8E322D2D7E734B169FF5FC
-
-#include "cmemlink.h"
-#include "ualgo.h"
-#include "uassert.h"
-
-namespace ustl {
-
-/// \class memlink memlink.h ustl.h
-/// \ingroup MemoryManagement
-///
-/// \brief Wrapper for pointer to block with size.
-///
-/// Use this class the way you would a pointer to an allocated unstructured block.
-/// The pointer and block size are available through member functions and cast operator.
-///
-/// Example usage:
-/// \code
-/// void* p = malloc (46721);
-/// memlink a, b;
-/// a.link (p, 46721);
-/// assert (a.size() == 46721));
-/// b = a;
-/// assert (b.size() == 46721));
-/// assert (b.begin() + 34 == a.begin + 34);
-/// assert (0 == memcmp (a, b, 12));
-/// a.fill (673, b, 42, 67);
-/// b.erase (87, 12);
-/// \endcode
-///
-class memlink : public cmemlink {
-public:
- typedef value_type* pointer;
- typedef cmemlink::pointer const_pointer;
- typedef cmemlink::const_iterator const_iterator;
- typedef pointer iterator;
- typedef const memlink& rcself_t;
-public:
- inline memlink (void) : cmemlink() {}
- inline memlink (void* p, size_type n) : cmemlink (p, n) {}
- inline memlink (const void* p, size_type n) : cmemlink (p, n) {}
- inline memlink (rcself_t l) : cmemlink (l) {}
- inline explicit memlink (const cmemlink& l) : cmemlink (l) {}
- inline pointer data (void) { return (const_cast<pointer>(cdata())); }
- inline iterator begin (void) { return (iterator (data())); }
- inline iterator iat (size_type i) { assert (i <= size()); return (begin() + i); }
- inline iterator end (void) { return (iat (size())); }
- inline const_iterator begin (void) const { return (cmemlink::begin()); }
- inline const_iterator end (void) const { return (cmemlink::end()); }
- inline const_iterator iat (size_type i) const { return (cmemlink::iat (i)); }
- size_type writable_size (void) const { return (size()); }
- inline rcself_t operator= (const cmemlink& l) { cmemlink::operator= (l); return (*this); }
- inline rcself_t operator= (rcself_t l) { cmemlink::operator= (l); return (*this); }
- inline void link (const void* p, size_type n) { cmemlink::link (p, n); }
- inline void link (void* p, size_type n) { cmemlink::link (p, n); }
- inline void link (const cmemlink& l) { cmemlink::link (l); }
- inline void link (memlink& l) { cmemlink::link (l); }
- OVERLOAD_POINTER_AND_SIZE_T_V2(link, void*)
- OVERLOAD_POINTER_AND_SIZE_T_V2(link, const void*)
- inline void link (const void* first, const void* last) { link (first, distance (first, last)); }
- inline void link (void* first, void* last) { link (first, distance (first, last)); }
- inline void relink (const void* p, size_type n) { cmemlink::relink (p, n); }
- inline void relink (void* p, size_type n) { cmemlink::relink (p, n); }
- inline void copy (const cmemlink& l) { copy (begin(), l.cdata(), l.size()); }
- inline void copy (const void* p, size_type n) { copy (begin(), p, n); }
- void copy (iterator offset, const void* p, size_type n);
- inline void swap (memlink& l) { cmemlink::swap (l); }
- void fill (iterator start, const void* p, size_type elsize, size_type elCount = 1);
- inline void insert (iterator start, size_type size);
- inline void erase (iterator start, size_type size);
- void read (istream& is);
-};
-
-/// Shifts the data in the linked block from \p start to \p start + \p n.
-/// The contents of the uncovered bytes is undefined.
-inline void memlink::insert (iterator start, size_type n)
-{
- assert (data() || !n);
- assert (cmemlink::begin() || !n);
- assert (start >= begin() && start + n <= end());
- rotate (start, end() - n, end());
-}
-
-/// Shifts the data in the linked block from \p start + \p n to \p start.
-/// The contents of the uncovered bytes is undefined.
-inline void memlink::erase (iterator start, size_type n)
-{
- assert (data() || !n);
- assert (cmemlink::begin() || !n);
- assert (start >= begin() && start + n <= end());
- rotate (start, start + n, end());
-}
-
-/// Reads object \p l from stream \p is
-inline istream& operator>> (istream& is, memlink& l)
-{
- l.read (is);
- return (is);
-}
-
-/// Use with memlink-derived classes to allocate and link to stack space.
-#define alloca_link(m,n) (m).link (alloca (n), (n))
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/mistream.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/mistream.cpp
deleted file mode 100644
index ad99828..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/mistream.cpp
+++ /dev/null
@@ -1,242 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// mstream.cpp
-//
-// Helper classes to read and write packed binary streams.
-//
-
-#include "mistream.h"
-#include "sostream.h"
-#include "ualgo.h"
-#include "uassert.h"
-#include "ustring.h"
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-#endif
-
-namespace ustl {
-
-//--------------------------------------------------------------------
-
-/// \brief Constructs a stream attached to nothing.
-/// A stream attached to nothing is not usable. Call Link() functions
-/// inherited from cmemlink to attach to some memory block.
-///
-istream::istream (void)
-: cmemlink (),
- m_Pos (0)
-{
-}
-
-/// Attaches the stream to a block at \p p of size \p n.
-istream::istream (const void* p, size_type n)
-: cmemlink (p, n),
- m_Pos (0)
-{
-}
-
-/// Attaches to the block pointed to by \p source.
-istream::istream (const cmemlink& source)
-: cmemlink (source),
- m_Pos (0)
-{
-}
-
-/// Attaches to the block pointed to by source of size source.pos()
-istream::istream (const ostream& source)
-: cmemlink (source.begin(), source.pos()),
- m_Pos (0)
-{
-}
-
-/// Swaps contents with \p is
-void istream::swap (istream& is)
-{
- cmemlink::swap (is);
- ::ustl::swap (m_Pos, is.m_Pos);
-}
-
-/// Checks that \p n bytes are available in the stream, or else throws.
-void istream::verify_remaining (const char* op, const char* type, size_t n) const
-{
- if (remaining() < n)
-#if PLATFORM_ANDROID
- printf("stream bounds exception\n");
-#else
- throw stream_bounds_exception (op, type, pos(), n, remaining());
-#endif
-}
-
-/// Reads \p n bytes into \p buffer.
-void istream::read (void* buffer, size_type n)
-{
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- verify_remaining ("read", "binary data", n);
-#else
- assert (remaining() >= n && "Reading past end of buffer. Make sure you are reading the right format.");
-#endif
- copy_n (ipos(), n, reinterpret_cast<value_type*>(buffer));
- m_Pos += n;
-}
-
-/// Reads a null-terminated string into \p str.
-void istream::read_strz (string& str)
-{
- const_iterator zp = find (ipos(), end(), string::c_Terminator);
- if (zp == end())
- zp = ipos();
- const size_type strl = distance (ipos(), zp);
- str.resize (strl);
- copy (ipos(), zp, str.begin());
- m_Pos += strl + 1;
-}
-
-/// Reads at most \p n bytes into \p s.
-istream::size_type istream::readsome (void* s, size_type n)
-{
- if (remaining() < n)
- underflow (n);
- const size_type ntr (min (n, remaining()));
- read (s, ntr);
- return (ntr);
-}
-
-/// Writes all unread bytes into \p os.
-void istream::write (ostream& os) const
-{
- os.write (ipos(), remaining());
-}
-
-/// Writes the object to stream \p os.
-void istream::text_write (ostringstream& os) const
-{
- os.write (ipos(), remaining());
-}
-
-/// Links to \p p of size \p n
-void istream::unlink (void)
-{
- cmemlink::unlink();
- m_Pos = 0;
-}
-
-//--------------------------------------------------------------------
-
-/// \brief Constructs a stream attached to nothing.
-/// A stream attached to nothing is not usable. Call Link() functions
-/// inherited from memlink to attach to some memory block.
-///
-ostream::ostream (void)
-: memlink (),
- m_Pos (0)
-{
-}
-
-/// Attaches the stream to a block at \p p of size \p n.
-ostream::ostream (void* p, size_type n)
-: memlink (p, n),
- m_Pos (0)
-{
-}
-
-/// Attaches to the block pointed to by \p source.
-ostream::ostream (const memlink& source)
-: memlink (source),
- m_Pos (0)
-{
-}
-
-/// Links to \p p of size \p n
-void ostream::unlink (void)
-{
- memlink::unlink();
- m_Pos = 0;
-}
-
-/// Checks that \p n bytes are available in the stream, or else throws.
-void ostream::verify_remaining (const char* op, const char* type, size_t n) const
-{
- if (remaining() < n)
-#if PLATFORM_ANDROID
- printf("stream bounds exception\n");
-#else
- throw stream_bounds_exception (op, type, pos(), n, remaining());
-#endif
-}
-
-/// Aligns the write pointer on \p grain. The skipped bytes are zeroed.
-void ostream::align (size_type grain)
-{
- const size_t r = pos() % grain;
- size_t nb = grain - r;
- if (!r) nb = 0;
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- verify_remaining ("align", "padding", nb);
-#else
- assert (remaining() >= nb && "Buffer overrun. Check your stream size calculations.");
-#endif
- fill_n (ipos(), nb, '\x0');
- m_Pos += nb;
-}
-
-/// Writes \p n bytes from \p buffer.
-void ostream::write (const void* buffer, size_type n)
-{
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- verify_remaining ("write", "binary data", n);
-#else
- assert (remaining() >= n && "Buffer overrun. Check your stream size calculations.");
-#endif
- copy_n (const_iterator(buffer), n, ipos());
- m_Pos += n;
-}
-
-/// Writes \p str as a null-terminated string.
-void ostream::write_strz (const char* str)
-{
- write (str, strlen(str));
- iwrite (string::c_Terminator);
-}
-
-/// Writes all available data from \p is.
-void ostream::read (istream& is)
-{
- is.write (*this);
- is.seek (is.size());
-}
-
-/// Writes all written data to \p os.
-void ostream::text_write (ostringstream& os) const
-{
- os.write (begin(), pos());
-}
-
-/// Inserts an empty area of \p size, at \p start.
-void ostream::insert (iterator start, size_type s)
-{
- memlink::insert (start, s);
- m_Pos += s;
-}
-
-/// Erases an area of \p size, at \p start.
-void ostream::erase (iterator start, size_type s)
-{
- m_Pos -= s;
- memlink::erase (start, s);
-}
-
-/// Swaps with \p os
-void ostream::swap (ostream& os)
-{
- memlink::swap (os);
- ::ustl::swap (m_Pos, os.m_Pos);
-}
-
-//--------------------------------------------------------------------
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/mistream.h b/media/libdrm/mobile2/src/util/ustl-1.0/mistream.h
deleted file mode 100644
index 0a7aee7..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/mistream.h
+++ /dev/null
@@ -1,293 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// mistream.h
-//
-#ifndef MISTREAM_H_103AEF1F266C04AA1A817D38705983DA
-#define MISTREAM_H_103AEF1F266C04AA1A817D38705983DA
-
-#include "memlink.h"
-#include "uexception.h"
-#include "strmsize.h"
-#include "uassert.h"
-#include "utf8.h"
-#include "uios.h"
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- #include <typeinfo>
-#endif
-
-namespace ustl {
-
-class ostream;
-class memlink;
-class string;
-
-/// \class istream mistream.h ustl.h
-/// \ingroup BinaryStreams
-///
-/// \brief Helper class to read packed binary streams.
-///
-/// This class contains a set of functions to read integral types from an
-/// unstructured memory block. Unpacking binary file data can be done this
-/// way, for instance. aligning the data is your responsibility, and can
-/// be accomplished by proper ordering of reads and by calling the align()
-/// function. Unaligned access is usually slower by orders of magnitude and,
-/// on some architectures, such as PowerPC, can cause your program to crash.
-/// Therefore, all read functions have asserts to check alignment.
-/// Overreading the end of the stream will also cause a crash (an assert in
-/// debug builds). Oh, and don't be intimidated by the size of the inlines
-/// here. In the assembly code the compiler will usually chop everything down
-/// to five instructions each.
-///
-/// Alignment rules for your objects:
-/// - Assume your writes start off 4-byte aligned.
-/// - After completion, \ref istream::align the stream to at least 4.
-/// - If data portability between 32bit and 64bit platforms is important
-/// (it often is not, in config files and the like), ensure you are always
-/// using fixed-size types and are aligning to a fixed grain. Avoid writing
-/// 8-byte types, and if you do, manually align before doing so.
-/// - Non-default alignment is allowed if you plan to frequently write this
-/// object in array form and alignment would be costly. For example, an
-/// array of uint16_t-sized objects may leave the stream uint16_t aligned
-/// as long as you know about it and will default-align the stream after
-/// writing the array (note: \ref vector will already do this for you)
-///
-/// Example code:
-/// \code
-/// memblock b;
-/// b.read_file ("test.file");
-/// ostream is (b);
-/// is >> boolVar >> ios::talign<int>();
-/// is >> intVar >> floatVar;
-/// is.read (binaryData, binaryDataSize);
-/// is.align();
-/// \endcode
-///
-class istream : public cmemlink, public ios_base {
-public:
- istream (void);
- istream (const void* p, size_type n);
- explicit istream (const cmemlink& source);
- explicit istream (const ostream& source);
- inline iterator end (void) const { return (cmemlink::end()); }
- inline void link (const void* p, size_type n) { cmemlink::link (p, n); }
- inline void link (const cmemlink& l) { cmemlink::link (l.cdata(), l.readable_size()); }
- inline void link (const void* f, const void* l) { cmemlink::link (f, l); }
- OVERLOAD_POINTER_AND_SIZE_T_V2(link, const void*)
- inline void relink (const void* p, size_type n) { cmemlink::relink (p, n); m_Pos = 0; }
- inline void relink (const cmemlink& l) { relink (l.cdata(), l.readable_size()); }
- virtual void unlink (void);
- inline virtual size_type underflow (size_type = 1) { return (remaining()); }
- inline uoff_t pos (void) const { return (m_Pos); }
- inline const_iterator ipos (void) const { return (begin() + pos()); }
- inline size_type remaining (void) const { return (size() - pos()); }
- inline void seek (uoff_t newPos);
- inline void iseek (const_iterator newPos);
- inline void skip (size_type nBytes);
- inline bool aligned (size_type grain = c_DefaultAlignment) const;
- void verify_remaining (const char* op, const char* type, size_t n) const;
- inline size_type align_size (size_type grain = c_DefaultAlignment) const;
- inline void align (size_type grain = c_DefaultAlignment);
- void swap (istream& is);
- void read (void* buffer, size_type size);
- inline void read (memlink& buf) { read (buf.begin(), buf.writable_size()); }
- void read_strz (string& str);
- size_type readsome (void* s, size_type n);
- inline void read (istream&) { }
- void write (ostream& os) const;
- void text_write (ostringstream& os) const;
- inline size_t stream_size (void) const { return (remaining()); }
- template <typename T>
- inline void iread (T& v);
- inline void ungetc (void) { seek (pos() - 1); }
- inline off_t tellg (void) const { return (pos()); }
- inline void seekg (off_t p, seekdir d = beg);
-private:
- uoff_t m_Pos; ///< The current read position.
-};
-
-//----------------------------------------------------------------------
-
-template <typename T, typename Stream>
-inline size_t required_stream_size (T, const Stream&) { return (1); }
-template <typename T>
-inline size_t required_stream_size (T v, const istream&) { return (stream_size_of(v)); }
-
-template <typename Stream>
-inline bool stream_at_eof (const Stream& stm) { return (stm.eof()); }
-template <>
-inline bool stream_at_eof (const istream&) { return (false); }
-
-/// \class istream_iterator
-/// \ingroup BinaryStreamIterators
-///
-/// \brief An iterator over an istream to use with uSTL algorithms.
-///
-template <typename T, typename Stream = istream>
-class istream_iterator {
-public:
- typedef T value_type;
- typedef ptrdiff_t difference_type;
- typedef const value_type* pointer;
- typedef const value_type& reference;
- typedef size_t size_type;
-public:
- istream_iterator (void) : m_pis (NULL), m_v() {}
- explicit istream_iterator (Stream& is) : m_pis (&is), m_v() { Read(); }
- istream_iterator (const istream_iterator& i) : m_pis (i.m_pis), m_v (i.m_v) {}
- /// Reads and returns the next value.
- inline const T& operator* (void) { return (m_v); }
- inline istream_iterator& operator++ (void) { Read(); return (*this); }
- inline istream_iterator& operator-- (void) { m_pis->seek (m_pis->pos() - 2 * stream_size_of(m_v)); return (operator++()); }
- inline istream_iterator operator++ (int) { istream_iterator old (*this); operator++(); return (old); }
- inline istream_iterator operator-- (int) { istream_iterator old (*this); operator--(); return (old); }
- inline istream_iterator& operator+= (size_type n) { while (n--) operator++(); return (*this); }
- inline istream_iterator& operator-= (size_type n) { m_pis->seek (m_pis->pos() - (n + 1) * stream_size_of(m_v)); return (operator++()); }
- inline istream_iterator operator- (size_type n) const { istream_iterator result (*this); return (result -= n); }
- inline difference_type operator- (const istream_iterator& i) const { return (distance (i.m_pis->pos(), m_pis->pos()) / stream_size_of(m_v)); }
- inline bool operator== (const istream_iterator& i) const { return ((!m_pis && !i.m_pis) || (m_pis && i.m_pis && m_pis->pos() == i.m_pis->pos())); }
- inline bool operator< (const istream_iterator& i) const { return (!i.m_pis || (m_pis && m_pis->pos() < i.m_pis->pos())); }
-private:
- void Read (void)
- {
- if (!m_pis)
- return;
- const size_t rs (required_stream_size (m_v, *m_pis));
- if (m_pis->remaining() < rs && m_pis->underflow (rs) < rs) {
- m_pis = NULL;
- return;
- }
- *m_pis >> m_v;
- if (stream_at_eof (*m_pis))
- m_pis = NULL;
- }
-private:
- Stream* m_pis; ///< The host stream.
- T m_v; ///< Last read value; cached to be returnable as a const reference.
-};
-
-//----------------------------------------------------------------------
-
-/// Sets the current read position to \p newPos
-inline void istream::seek (uoff_t newPos)
-{
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- if (newPos > size())
- throw stream_bounds_exception ("seekg", "byte", pos(), newPos - pos(), size());
-#else
- assert (newPos <= size());
-#endif
- m_Pos = newPos;
-}
-
-/// Sets the current read position to \p newPos
-inline void istream::iseek (const_iterator newPos)
-{
- seek (distance (begin(), newPos));
-}
-
-/// Sets the current write position to \p p based on \p d.
-inline void istream::seekg (off_t p, seekdir d)
-{
- switch (d) {
- case beg: seek (p); break;
- case cur: seek (pos() + p); break;
- case ios_base::end: seek (size() - p); break;
- }
-}
-
-/// Skips \p nBytes without reading them.
-inline void istream::skip (size_type nBytes)
-{
- seek (pos() + nBytes);
-}
-
-/// Returns the number of bytes to skip to be aligned on \p grain.
-inline istream::size_type istream::align_size (size_type grain) const
-{
- return (Align (pos(), grain) - pos());
-}
-
-/// Returns \c true if the read position is aligned on \p grain
-inline bool istream::aligned (size_type grain) const
-{
- assert (uintptr_t(begin()) % grain == 0 && "Streams should be attached aligned at the maximum element grain to avoid bus errors.");
- return (pos() % grain == 0);
-}
-
-/// aligns the read position on \p grain
-inline void istream::align (size_type grain)
-{
- seek (Align (pos(), grain));
-}
-
-/// Reads type T from the stream via a direct pointer cast.
-template <typename T>
-inline void istream::iread (T& v)
-{
- assert (aligned (alignof (T())));
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- verify_remaining ("read", typeid(v).name(), sizeof(T));
-#else
- assert (remaining() >= sizeof(T));
-#endif
- v = *reinterpret_cast<const T*>(ipos());
- m_Pos += sizeof(T);
-}
-
-#define ISTREAM_OPERATOR(type) \
-inline istream& operator>> (istream& is, type& v) { is.iread(v); return (is); }
-
-template <typename T>
-ISTREAM_OPERATOR(T*)
-ISTREAM_OPERATOR(int8_t)
-ISTREAM_OPERATOR(uint8_t)
-ISTREAM_OPERATOR(int16_t)
-ISTREAM_OPERATOR(uint16_t)
-ISTREAM_OPERATOR(int32_t)
-ISTREAM_OPERATOR(uint32_t)
-ISTREAM_OPERATOR(float)
-ISTREAM_OPERATOR(double)
-ISTREAM_OPERATOR(wchar_t)
-#if SIZE_OF_BOOL == SIZE_OF_CHAR
-ISTREAM_OPERATOR(bool)
-#else
-inline istream& operator>> (istream& is, bool& v)
-{ uint8_t v8; is.iread (v8); v = v8; return (is); }
-#endif
-#if HAVE_THREE_CHAR_TYPES
-ISTREAM_OPERATOR(char)
-#endif
-#if HAVE_INT64_T
-ISTREAM_OPERATOR(int64_t)
-ISTREAM_OPERATOR(uint64_t)
-#endif
-#if SIZE_OF_LONG == SIZE_OF_INT
-ISTREAM_OPERATOR(long)
-ISTREAM_OPERATOR(unsigned long)
-#endif
-#if HAVE_LONG_LONG && (!HAVE_INT64_T || SIZE_OF_LONG_LONG > 8)
-ISTREAM_OPERATOR(long long)
-ISTREAM_OPERATOR(unsigned long long)
-#endif
-
-//----------------------------------------------------------------------
-
-typedef istream_iterator<utf8subchar_t> istream_iterator_for_utf8;
-typedef utf8in_iterator<istream_iterator_for_utf8> utf8istream_iterator;
-
-/// Returns a UTF-8 adaptor reading from \p is.
-inline utf8istream_iterator utf8in (istream& is)
-{
- istream_iterator_for_utf8 si (is);
- return (utf8istream_iterator (si));
-}
-
-//----------------------------------------------------------------------
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/mostream.h b/media/libdrm/mobile2/src/util/ustl-1.0/mostream.h
deleted file mode 100644
index fb04196..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/mostream.h
+++ /dev/null
@@ -1,260 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// mostream.h
-
-#ifndef MOSTREAM_H_24A8C5397E0848216573E5670930FC9A
-#define MOSTREAM_H_24A8C5397E0848216573E5670930FC9A
-
-#include "memlink.h"
-#include "uassert.h"
-#include "uexception.h"
-#include "utf8.h"
-#include "uios.h"
-#include <typeinfo>
-
-namespace ustl {
-
-class istream;
-class string;
-
-/// \class ostream mostream.h ustl.h
-/// \ingroup BinaryStreams
-///
-/// \brief Helper class to write packed binary streams.
-///
-/// This class contains a set of functions to write integral types into an
-/// unstructured memory block. Packing binary file data can be done this
-/// way, for instance. aligning the data is your responsibility, and can
-/// be accomplished by proper ordering of writes and by calling \ref ostream::align.
-/// Unaligned access is usually slower by orders of magnitude and,
-/// on some architectures, such as PowerPC, can cause your program to crash.
-/// Therefore, all write functions have asserts to check alignment.
-/// See \ref istream documentation for rules on designing your data format.
-/// Overwriting the end of the stream will also cause a crash (an assert in
-/// debug builds). Oh, and don't be intimidated by the size of the inlines
-/// here. In the assembly code the compiler will usually chop everything down
-/// to five instructions each.
-///
-/// Example code:
-/// \code
-/// memblock b;
-/// ostream os (b);
-/// os << boolVar << ios::talign<int>();
-/// os << intVar << floatVar;
-/// os.write (binaryData, binaryDataSize);
-/// os.align();
-/// b.resize (os.pos());
-/// b.write_file ("test.file");
-/// \endcode
-///
-class ostream : public memlink, public ios_base {
-public:
- ostream (void);
- ostream (void* p, size_type n);
- explicit ostream (const memlink& source);
- inline iterator end (void) { return (memlink::end()); }
- inline const_iterator end (void) const { return (memlink::end()); }
- inline void seek (uoff_t newPos);
- inline void iseek (const_iterator newPos);
- inline void skip (size_type nBytes);
- inline uoff_t pos (void) const { return (m_Pos); }
- inline iterator ipos (void) { return (begin() + pos()); }
- inline const_iterator ipos (void) const { return (begin() + pos()); }
- inline size_type remaining (void) const;
- inline bool aligned (size_type grain = c_DefaultAlignment) const;
- void verify_remaining (const char* op, const char* type, size_t n) const;
- inline size_type align_size (size_type grain = c_DefaultAlignment) const;
- void align (size_type grain = c_DefaultAlignment);
- void write (const void* buffer, size_type size);
- inline void write (const cmemlink& buf);
- void write_strz (const char* str);
- void read (istream& is);
- inline void write (ostream& os) const { os.write (begin(), pos()); }
- void text_write (ostringstream& os) const;
- inline size_t stream_size (void) const { return (pos()); }
- void insert (iterator start, size_type size);
- void erase (iterator start, size_type size);
- void swap (ostream& os);
- template <typename T>
- inline void iwrite (const T& v);
- inline virtual size_type overflow (size_type = 1){ return (remaining()); }
- virtual void unlink (void);
- inline void link (void* p, size_type n) { memlink::link (p, n); }
- inline void link (memlink& l) { memlink::link (l.data(), l.writable_size()); }
- inline void link (void* f, void* l) { memlink::link (f, l); }
- OVERLOAD_POINTER_AND_SIZE_T_V2(link, void*)
- inline void relink (void* p, size_type n) { memlink::relink (p, n); m_Pos = 0; }
- inline void relink (memlink& l) { relink (l.data(), l.writable_size()); }
- inline void seekp (off_t p, seekdir d = beg);
- inline off_t tellp (void) const { return (pos()); }
-protected:
- inline void SetPos (uoff_t newPos) { m_Pos = newPos; }
-private:
- uoff_t m_Pos; ///< Current write position.
-};
-
-//----------------------------------------------------------------------
-
-/// \class ostream_iterator mostream.h ustl.h
-/// \ingroup BinaryStreamIterators
-///
-/// \brief An iterator over an ostream to use with uSTL algorithms.
-///
-template <typename T, typename Stream = ostream>
-class ostream_iterator {
-public:
- typedef T value_type;
- typedef ptrdiff_t difference_type;
- typedef value_type* pointer;
- typedef value_type& reference;
- typedef ostream::size_type size_type;
-public:
- inline explicit ostream_iterator (Stream& os)
- : m_Os (os) {}
- inline ostream_iterator (const ostream_iterator& iter)
- : m_Os (iter.m_Os) {}
- /// Writes \p v into the stream.
- inline ostream_iterator& operator= (const T& v)
- { m_Os << v; return (*this); }
- inline ostream_iterator& operator* (void) { return (*this); }
- inline ostream_iterator& operator++ (void) { return (*this); }
- inline ostream_iterator operator++ (int) { return (*this); }
- inline ostream_iterator& operator+= (size_type n) { m_Os.skip (n); return (*this); }
- inline bool operator== (const ostream_iterator& i) const
- { return (m_Os.pos() == i.m_Os.pos()); }
- inline bool operator< (const ostream_iterator& i) const
- { return (m_Os.pos() < i.m_Os.pos()); }
-private:
- Stream& m_Os;
-};
-
-//----------------------------------------------------------------------
-
-typedef ostream_iterator<utf8subchar_t> ostream_iterator_for_utf8;
-typedef utf8out_iterator<ostream_iterator_for_utf8> utf8ostream_iterator;
-
-/// Returns a UTF-8 adaptor writing to \p os.
-inline utf8ostream_iterator utf8out (ostream& os)
-{
- ostream_iterator_for_utf8 si (os);
- return (utf8ostream_iterator (si));
-}
-
-//----------------------------------------------------------------------
-
-/// Move the write pointer to \p newPos
-inline void ostream::seek (uoff_t newPos)
-{
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- if (newPos > size())
- throw stream_bounds_exception ("seekp", "byte", pos(), newPos - pos(), size());
-#else
- assert (newPos <= size());
-#endif
- SetPos (newPos);
-}
-
-/// Sets the current write position to \p newPos
-inline void ostream::iseek (const_iterator newPos)
-{
- seek (distance (begin(), const_cast<iterator>(newPos)));
-}
-
-/// Sets the current write position to \p p based on \p d.
-inline void ostream::seekp (off_t p, seekdir d)
-{
- switch (d) {
- case beg: seek (p); break;
- case cur: seek (pos() + p); break;
- case ios_base::end: seek (size() - p); break;
- }
-}
-
-/// Skips \p nBytes without writing anything.
-inline void ostream::skip (size_type nBytes)
-{
- seek (pos() + nBytes);
-}
-
-/// Returns number of bytes remaining in the write buffer.
-inline ostream::size_type ostream::remaining (void) const
-{
- return (size() - pos());
-}
-
-/// Returns \c true if the write pointer is aligned on \p grain
-inline bool ostream::aligned (size_type grain) const
-{
- assert (uintptr_t(begin()) % grain == 0 && "Streams should be attached aligned at the maximum element grain to avoid bus errors.");
- return (pos() % grain == 0);
-}
-
-/// Returns the number of bytes to skip to be aligned on \p grain.
-inline ostream::size_type ostream::align_size (size_type grain) const
-{
- return (Align (pos(), grain) - pos());
-}
-
-/// Writes the contents of \p buf into the stream as a raw dump.
-inline void ostream::write (const cmemlink& buf)
-{
- write (buf.begin(), buf.size());
-}
-
-/// Writes type T into the stream via a direct pointer cast.
-template <typename T>
-inline void ostream::iwrite (const T& v)
-{
- assert (aligned (alignof (v)));
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- verify_remaining ("write", typeid(v).name(), sizeof(T));
-#else
- assert (remaining() >= sizeof(T));
-#endif
- *reinterpret_cast<T*>(ipos()) = v;
- SetPos (pos() + sizeof(T));
-}
-
-#define OSTREAM_OPERATOR(type) \
-inline ostream& operator<< (ostream& os, type v) { os.iwrite(v); return (os); }
-
-template <typename T>
-OSTREAM_OPERATOR(T*)
-OSTREAM_OPERATOR(int8_t)
-OSTREAM_OPERATOR(uint8_t)
-OSTREAM_OPERATOR(int16_t)
-OSTREAM_OPERATOR(uint16_t)
-OSTREAM_OPERATOR(int32_t)
-OSTREAM_OPERATOR(uint32_t)
-OSTREAM_OPERATOR(float)
-OSTREAM_OPERATOR(double)
-OSTREAM_OPERATOR(wchar_t)
-#if SIZE_OF_BOOL == SIZE_OF_CHAR
-OSTREAM_OPERATOR(bool)
-#else
-inline ostream& operator<< (ostream& os, bool v)
-{ os.iwrite (uint8_t(v)); return (os); }
-#endif
-#if HAVE_THREE_CHAR_TYPES
-OSTREAM_OPERATOR(char)
-#endif
-#if HAVE_INT64_T
-OSTREAM_OPERATOR(int64_t)
-OSTREAM_OPERATOR(uint64_t)
-#endif
-#if SIZE_OF_LONG == SIZE_OF_INT
-OSTREAM_OPERATOR(long)
-OSTREAM_OPERATOR(unsigned long)
-#endif
-#if HAVE_LONG_LONG && (!HAVE_INT64_T || SIZE_OF_LONG_LONG > 8)
-OSTREAM_OPERATOR(long long)
-OSTREAM_OPERATOR(unsigned long long)
-#endif
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ofstream.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/ofstream.cpp
deleted file mode 100644
index 0948a4d..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ofstream.cpp
+++ /dev/null
@@ -1,163 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ofstream.cc
-//
-
-#include "ofstream.h"
-#include "ustring.h"
-#include "uexception.h"
-#include <unistd.h>
-#include <errno.h>
-#include <stdio.h>
-#include <stdarg.h>
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-
-ifstream cin (STDIN_FILENO);
-ofstream cout (STDOUT_FILENO);
-ofstream cerr (STDERR_FILENO);
-
-//----------------------------------------------------------------------
-
-/// Default constructor.
-ofstream::ofstream (void)
-: ostringstream (),
- m_File ()
-{
- reserve (255);
-}
-
-/// Constructs a stream for writing to \p Fd.
-ofstream::ofstream (int Fd)
-: ostringstream (),
- m_File (Fd)
-{
- clear (m_File.rdstate());
- reserve (255);
-}
-
-/// Constructs a stream for writing to \p filename.
-ofstream::ofstream (const char* filename, openmode mode)
-: ostringstream (),
- m_File (filename, mode)
-{
- clear (m_File.rdstate());
-}
-
-/// Default destructor.
-ofstream::~ofstream (void)
-{
-#if PLATFORM_ANDROID
- flush();
-#else /* !PLATFORM_ANDROID */
- try { flush(); } catch (...) {}
-#endif
-}
-
-/// Flushes the buffer to the file.
-void ofstream::flush (void)
-{
- while (pos() && overflow (remaining()));
- m_File.sync();
- clear (m_File.rdstate());
-}
-
-/// Seeks to \p p based on \p d.
-void ofstream::seekp (off_t p, seekdir d)
-{
- flush();
- m_File.seekp (p, d);
- clear (m_File.rdstate());
-}
-
-/// Called when more buffer space (\p n bytes) is needed.
-ofstream::size_type ofstream::overflow (size_type n)
-{
- if (eof() || (n > remaining() && n < capacity() - pos()))
- return (ostringstream::overflow (n));
- size_type bw = m_File.write (cdata(), pos());
- clear (m_File.rdstate());
- erase (begin(), bw);
- if (remaining() < n)
- ostringstream::overflow (n);
- return (remaining());
-}
-
-//----------------------------------------------------------------------
-
-/// Constructs a stream to read from \p Fd.
-ifstream::ifstream (int Fd)
-: istringstream (),
- m_Buffer (255),
- m_File (Fd)
-{
- link (m_Buffer.data(), 0U);
-}
-
-/// Constructs a stream to read from \p filename.
-ifstream::ifstream (const char* filename, openmode mode)
-: istringstream (),
- m_Buffer (255),
- m_File (filename, mode)
-{
- clear (m_File.rdstate());
- link (m_Buffer.data(), 0U);
-}
-
-/// Reads at least \p n more bytes and returns available bytes.
-ifstream::size_type ifstream::underflow (size_type n)
-{
- if (eof())
- return (istringstream::underflow (n));
-
- const ssize_t freeSpace = m_Buffer.size() - pos();
- const ssize_t neededFreeSpace = max (n, m_Buffer.size() / 2);
- const size_t oughtToErase = Align (max (0, neededFreeSpace - freeSpace));
- const size_t nToErase = min (pos(), oughtToErase);
- m_Buffer.memlink::erase (m_Buffer.begin(), nToErase);
- const uoff_t oldPos (pos() - nToErase);
-
- size_type br = oldPos;
- if (m_Buffer.size() - br < n) {
- m_Buffer.resize (br + neededFreeSpace);
- link (m_Buffer.data(), 0U);
- }
- cout.flush();
-
- while (br - oldPos < n && m_File.good())
- br += m_File.readsome (m_Buffer.begin() + br, m_Buffer.size() - br);
- clear (m_File.rdstate());
-
- m_Buffer[br] = string::c_Terminator;
- link (m_Buffer.data(), br);
- seek (oldPos);
- return (remaining());
-}
-
-/// Flushes the input.
-void ifstream::sync (void)
-{
- istringstream::sync();
- underflow (0U);
- m_File.sync();
- clear (m_File.rdstate());
-}
-
-/// Seeks to \p p based on \p d.
-void ifstream::seekg (off_t p, seekdir d)
-{
- m_Buffer.clear();
- link (m_Buffer);
- m_File.seekg (p, d);
- clear (m_File.rdstate());
-}
-
-//----------------------------------------------------------------------
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ofstream.h b/media/libdrm/mobile2/src/util/ustl-1.0/ofstream.h
deleted file mode 100644
index 7780833..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ofstream.h
+++ /dev/null
@@ -1,82 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ofstream.h
-//
-
-#ifndef FDOSTREAM_H_5E27FC3D530BF3CA04D6C73F5700EECC
-#define FDOSTREAM_H_5E27FC3D530BF3CA04D6C73F5700EECC
-
-#include "sistream.h"
-#include "sostream.h"
-#include "fstream.h"
-
-namespace ustl {
-
-/// \class ofstream fdostream.h ustl.h
-/// \ingroup DeviceStreams
-/// \brief A string stream that writes to an fd. Implements cout and cerr.
-class ofstream : public ostringstream {
-public:
- ofstream (void);
- explicit ofstream (int Fd);
- explicit ofstream (const char* filename, openmode mode = out);
- virtual ~ofstream (void);
- inline void open (const char* filename, openmode mode = out) { m_File.open (filename, mode); clear (m_File.rdstate()); }
- inline void close (void) { m_File.close(); clear (m_File.rdstate()); }
- inline bool is_open (void) const { return (m_File.is_open()); }
- inline iostate exceptions (iostate v) { ostringstream::exceptions(v); return (m_File.exceptions(v)); }
- inline void setstate (iostate v) { ostringstream::setstate(v); m_File.setstate(v); }
- inline void clear (iostate v = goodbit) { ostringstream::clear(v); m_File.clear(v); }
- inline off_t tellp (void) const { return (m_File.tellp() + ostringstream::tellp()); }
- inline int fd (void) const { return (m_File.fd()); }
- inline void stat (struct stat& rs) const { m_File.stat (rs); }
- inline void set_nonblock (bool v = true) { m_File.set_nonblock (v); }
- inline int ioctl (const char* rname, int request, long argument = 0) { return (m_File.ioctl (rname, request, argument)); }
- inline int ioctl (const char* rname, int request, int argument) { return (m_File.ioctl (rname, request, argument)); }
- inline int ioctl (const char* rname, int request, void* argument) { return (m_File.ioctl (rname, request, argument)); }
- void seekp (off_t p, seekdir d = beg);
- void flush (void);
- virtual size_type overflow (size_type n = 1);
-private:
- fstream m_File;
-};
-
-/// \class ifstream fdostream.h ustl.h
-/// \ingroup DeviceStreams
-/// \brief A string stream that reads from an fd. Implements cin.
-class ifstream : public istringstream {
-public:
- ifstream (void);
- explicit ifstream (int Fd);
- explicit ifstream (const char* filename, openmode mode = in);
- inline void open (const char* filename, openmode mode = in) { m_File.open (filename, mode); clear (m_File.rdstate()); }
- inline void close (void) { m_File.close(); clear (m_File.rdstate()); }
- inline bool is_open (void) const { return (m_File.is_open()); }
- inline iostate exceptions (iostate v) { istringstream::exceptions(v); return (m_File.exceptions(v)); }
- inline void setstate (iostate v) { istringstream::setstate(v); m_File.setstate(v); }
- inline void clear (iostate v = goodbit) { istringstream::clear(v); m_File.clear(v); }
- inline off_t tellg (void) const { return (m_File.tellg() - remaining()); }
- inline int fd (void) const { return (m_File.fd()); }
- inline void stat (struct stat& rs) const { m_File.stat (rs); }
- inline void set_nonblock (bool v = true) { m_File.set_nonblock (v); }
- inline int ioctl (const char* rname, int request, long argument = 0) { return (m_File.ioctl (rname, request, argument)); }
- inline int ioctl (const char* rname, int request, int argument) { return (m_File.ioctl (rname, request, argument)); }
- inline int ioctl (const char* rname, int request, void* argument) { return (m_File.ioctl (rname, request, argument)); }
- void seekg (off_t p, seekdir d = beg);
- void sync (void);
- virtual size_type underflow (size_type n = 1);
-private:
- string m_Buffer;
- fstream m_File;
-};
-
-extern ofstream cout, cerr;
-extern ifstream cin;
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/simd.h b/media/libdrm/mobile2/src/util/ustl-1.0/simd.h
deleted file mode 100644
index 950efc2..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/simd.h
+++ /dev/null
@@ -1,465 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-/// \file simd.h
-/// \brief SIMD-type algorithms, with hardware acceleration, if available.
-///
-/// All algorithms are container-based because iterator syntax is just too
-/// damn verbose and because the specializations need to be able to tell
-/// how many elements are in the container in order to choose proper SIMD
-/// instruction set (i.e.: 4 floats select SSE, while 2 floats select 3dNow!)
-/// Specializations are only for the tuple template because the container
-/// must be of a fixed and compile-time-known size for the compiler to be
-/// able to choose the specialization.
-///
-
-#ifndef SIMD_H_39BE2D970DF4BD00508CCFFB482496F9
-#define SIMD_H_39BE2D970DF4BD00508CCFFB482496F9
-
-#include "uassert.h"
-#include "ulimits.h"
-#if HAVE_MATH_H
- #include <math.h>
-#endif
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-#undef CPU_HAS_MMX
-#endif
-
-namespace ustl {
-namespace simd {
-
-//----------------------------------------------------------------------
-// Generic algorithms
-//----------------------------------------------------------------------
-
-/// Applies \p op to each element in \p op1.
-template <typename Ctr, typename UnaryOperation>
-inline void packop (Ctr& op1, UnaryOperation op)
-{
- foreach (typename Ctr::iterator, i, op1)
- op (*i);
-}
-
-/// Applies \p op to each element in \p op1 and \p op2 and stores in \p op2.
-template <typename Ctr, typename BinaryOperation>
-inline void packop (const Ctr& op1, Ctr& op2, BinaryOperation op)
-{
- assert (op2.size() <= op1.size());
- typename Ctr::const_iterator i1 (op1.begin());
- typename Ctr::iterator i2 (op2.begin());
- for (; i2 != op2.end(); ++i1, ++i2)
- *i2 = op (*i2, *i1);
-}
-
-/// Applies \p op to corresponding elements in \p op1 and \p op2 and stores in \p result.
-template <typename Ctr, typename BinaryOperation>
-inline void packop (const Ctr& op1, const Ctr& op2, Ctr& result, BinaryOperation op)
-{
- assert (op1.size() <= op2.size() && op1.size() <= result.size());
- passign (op1, result);
- packop (op2, result);
-}
-
-/// Copies \p op1 into \p result.
-template <typename Ctr>
-inline void passign (const Ctr& op1, Ctr& result)
-{
- assert (op1.size() <= result.size());
- typename Ctr::iterator d (result.begin());
- foreach (typename Ctr::const_iterator, s, op1)
- *d++ = *s;
-}
-
-/// Copies \p result.size() elements from \p op1 to \p result.
-template <typename Ctr>
-inline void ipassign (typename Ctr::const_iterator op1, Ctr& result)
-{
- foreach (typename Ctr::iterator, d, result)
- *d = *op1++;
-}
-
-template <typename Ctr1, typename Ctr2, typename ConvertFunction>
-inline void pconvert (const Ctr1& op1, Ctr2& op2, ConvertFunction f)
-{
- assert (op1.size() <= op2.size());
- typename Ctr1::const_iterator i1 (op1.begin());
- typename Ctr2::iterator i2 (op2.begin());
- for (; i1 != op1.end(); ++i1, ++i2)
- *i2 = f (*i1);
-}
-
-// Functionoids for SIMD operations, like saturation arithmetic, shifts, etc.
-STD_BINARY_FUNCTOR (fpadds, T, ((b > numeric_limits<T>::max() - a) ? numeric_limits<T>::max() : a + b))
-STD_BINARY_FUNCTOR (fpsubs, T, ((a < numeric_limits<T>::min() + b) ? numeric_limits<T>::min() : a - b))
-STD_BINARY_FUNCTOR (fpshl, T, (a << b))
-STD_BINARY_FUNCTOR (fpshr, T, (a >> b))
-STD_BINARY_FUNCTOR (fpmin, T, (min (a, b)))
-STD_BINARY_FUNCTOR (fpmax, T, (max (a, b)))
-STD_BINARY_FUNCTOR (fpavg, T, ((a + b + 1) / 2))
-STD_CONVERSION_FUNCTOR (fcast, (D(a)))
-#if HAVE_MATH_H
-STD_UNARY_FUNCTOR (fpreciprocal,T, (1 / a))
-STD_UNARY_FUNCTOR (fpsqrt, T, (reset_mmx(), T (sqrt (a))))
-STD_UNARY_FUNCTOR (fprecipsqrt, T, (reset_mmx(), 1 / T(sqrt (a))))
-STD_UNARY_FUNCTOR (fsin, T, (reset_mmx(), T (sin (a))))
-STD_UNARY_FUNCTOR (fcos, T, (reset_mmx(), T (cos (a))))
-STD_UNARY_FUNCTOR (ftan, T, (reset_mmx(), T (tan (a))))
-#if HAVE_RINTF
-STD_CONVERSION_FUNCTOR (fround, (reset_mmx(), D(rintf(a))))
-#else
-STD_CONVERSION_FUNCTOR (fround, (reset_mmx(), D(rint(a))))
-#endif
-template <> inline int32_t fround<double,int32_t>::operator()(const double& a) const { reset_mmx(); return (int32_t(rint(a))); }
-#endif
-template <> inline float fpavg<float>::operator()(const float& a, const float& b) const { return ((a + b) / 2); }
-template <> inline double fpavg<double>::operator()(const double& a, const double& b) const { return ((a + b) / 2); }
-
-#define SIMD_PACKEDOP1(name, operation) \
-template <typename Ctr> \
-inline void name (Ctr& op1) \
-{ \
- typedef typename Ctr::value_type value_t; \
- packop (op1, operation<value_t>()); \
-}
-#define SIMD_PACKEDOP2(name, operation) \
-template <typename Ctr> \
-inline void name (const Ctr& op1, Ctr& op2) \
-{ \
- typedef typename Ctr::value_type value_t; \
- packop (op1, op2, operation<value_t>()); \
-}
-#define SIMD_PACKEDOP3(name, operation) \
-template <typename Ctr> \
-inline void name (const Ctr& op1, const Ctr& op2, Ctr& result) \
-{ \
- typedef typename Ctr::value_type value_t; \
- packop (op1, op2, result, operation<value_t>()); \
-}
-#define SIMD_SINGLEOP1(name, operation) \
-template <typename T> \
-inline T name (T op) \
-{ \
- operation<T> obj; \
- return (obj(op)); \
-}
-#define SIMD_CONVERTOP(name, operation) \
-template <typename Ctr1, typename Ctr2> \
-inline void name (const Ctr1& op1, Ctr2& op2) \
-{ \
- typedef typename Ctr1::value_type value1_t; \
- typedef typename Ctr2::value_type value2_t; \
- pconvert (op1, op2, operation<value1_t, value2_t>());\
-}
-
-SIMD_PACKEDOP2 (padd, plus)
-SIMD_PACKEDOP2 (psub, minus)
-SIMD_PACKEDOP2 (pmul, multiplies)
-SIMD_PACKEDOP2 (pdiv, divides)
-SIMD_PACKEDOP2 (pand, bitwise_and)
-SIMD_PACKEDOP2 (por, bitwise_or)
-SIMD_PACKEDOP2 (pxor, bitwise_xor)
-SIMD_PACKEDOP2 (pshl, fpshl)
-SIMD_PACKEDOP2 (pshr, fpshr)
-SIMD_PACKEDOP2 (psubs, fpsubs)
-SIMD_PACKEDOP2 (pmin, fpmin)
-SIMD_PACKEDOP2 (pmax, fpmax)
-SIMD_PACKEDOP2 (pavg, fpavg)
-
-SIMD_PACKEDOP3 (padd, plus)
-SIMD_PACKEDOP3 (psub, minus)
-SIMD_PACKEDOP3 (pmul, multiplies)
-SIMD_PACKEDOP3 (pdiv, divides)
-SIMD_PACKEDOP3 (pand, bitwise_and)
-SIMD_PACKEDOP3 (por, bitwise_or)
-SIMD_PACKEDOP3 (pxor, bitwise_xor)
-SIMD_PACKEDOP3 (pshl, fpshl)
-SIMD_PACKEDOP3 (pshr, fpshr)
-SIMD_PACKEDOP3 (padds, fpadds)
-SIMD_PACKEDOP3 (psubs, fpsubs)
-SIMD_PACKEDOP3 (pmin, fpmin)
-SIMD_PACKEDOP3 (pmax, fpmax)
-SIMD_PACKEDOP3 (pavg, fpavg)
-
-#if HAVE_MATH_H
-SIMD_PACKEDOP1 (precip, fpreciprocal)
-SIMD_PACKEDOP1 (psqrt, fpsqrt)
-SIMD_PACKEDOP1 (precipsqrt, fprecipsqrt)
-SIMD_PACKEDOP1 (psin, fsin)
-SIMD_PACKEDOP1 (pcos, fcos)
-SIMD_PACKEDOP1 (ptan, ftan)
-
-SIMD_SINGLEOP1 (srecip, fpreciprocal)
-SIMD_SINGLEOP1 (ssqrt, fpsqrt)
-SIMD_SINGLEOP1 (srecipsqrt, fprecipsqrt)
-SIMD_SINGLEOP1 (ssin, fsin)
-SIMD_SINGLEOP1 (scos, fcos)
-SIMD_SINGLEOP1 (stan, ftan)
-
-SIMD_CONVERTOP (pround, fround)
-
-template <typename T> inline int32_t sround (T op) { fround<T,int32_t> obj; return (obj (op)); }
-#endif
-
-#undef SIMD_SINGLEOP1
-#undef SIMD_PACKEDOP3
-#undef SIMD_PACKEDOP2
-#undef SIMD_PACKEDOP1
-
-//----------------------------------------------------------------------
-// Vector types to cast tuple data to
-//----------------------------------------------------------------------
-
-#if HAVE_VECTOR_EXTENSIONS && __GNUC__ >= 4
-#define VECTOR_ATTRIBUTE(mode,vs) __attribute__((vector_size(vs)))
-#else
-#define VECTOR_ATTRIBUTE(mode,vs)
-#endif
-typedef uint8_t v8qi_t VECTOR_ATTRIBUTE (V8QI,8);
-typedef uint16_t v4hi_t VECTOR_ATTRIBUTE (V4HI,8);
-typedef uint16_t v8hi_t VECTOR_ATTRIBUTE (V8HI,16);
-typedef uint32_t v2si_t VECTOR_ATTRIBUTE (V2SI,8);
-typedef uint32_t v4si_t VECTOR_ATTRIBUTE (V4SI,16);
-#if HAVE_INT64_T
-typedef uint64_t v1di_t VECTOR_ATTRIBUTE (V1DI,8);
-#endif
-typedef float v2sf_t VECTOR_ATTRIBUTE (V2SF,8);
-typedef float v4sf_t VECTOR_ATTRIBUTE (V4SF,16);
-typedef double v2df_t VECTOR_ATTRIBUTE (V2DF,16);
-#undef VECTOR_ATTRIBUTE
-
-//----------------------------------------------------------------------
-// Hardware accelerated specializations
-//----------------------------------------------------------------------
-
-#define SIMD_PKOP2_SPEC(n, type, optype) \
-template <> \
-inline void packop (const tuple<n,type>& oin, tuple<n,type>& oout, optype<type>)
-#define SIMD_PASSIGN_SPEC(n, type) \
-template <> \
-inline void passign (const tuple<n,type>& oin, tuple<n,type>& oout)
-#define SIMD_IPASSIGN_SPEC(n, type) \
-template <> \
-inline void ipassign (tuple<n,type>::const_iterator oin, tuple<n,type>& oout)
-#define SIMD_CONVERT_SPEC(n, type1, type2, optype) \
-template <> \
-inline void pconvert (const tuple<n,type1>& oin, tuple<n,type2>& oout, optype<type1,type2>)
-
-#if CPU_HAS_MMX
-#define STD_MMX_ARGS "=m"(oout[0]) : "m"(oin[0]) : "mm0", "st", "memory"
-#define DBL_MMX_ARGS "=m"(oout[0]), "=m"(oout[2]) : "m"(oin[0]), "m"(oin[2]) : "mm0", "mm1", "st", "st(1)", "memory"
-#define MMX_PKOP2_SPEC(n,type,optype,instruction) \
-SIMD_PKOP2_SPEC(n,type,optype) \
-{ asm ("movq %0, %%mm0\n\t" #instruction " %1, %%mm0\n\tmovq %%mm0, %0" : STD_MMX_ARGS); reset_mmx(); }
-#define MMX_DBL_PKOP2_SPEC(n,type,optype,instruction) \
-SIMD_PKOP2_SPEC(n,type,optype) \
-{ asm ("movq %0, %%mm0\n\tmovq %1, %%mm1\n\t" #instruction " %2, %%mm0\n\t" #instruction " %3, %%mm1\n\tmovq %%mm0, %0\n\tmovq %%mm1, %1" : DBL_MMX_ARGS); reset_mmx(); }
-#define MMX_PASSIGN_SPEC(n,type) \
-SIMD_PASSIGN_SPEC(n,type) \
-{ asm ("movq %1, %%mm0\n\tmovq %%mm0, %0" : STD_MMX_ARGS); reset_mmx(); }
-#define MMX_DBL_PASSIGN_SPEC(n,type) \
-SIMD_PASSIGN_SPEC(n,type) \
-{ asm ("movq %2, %%mm0\n\tmovq %3, %%mm1\n\tmovq %%mm0, %0\n\tmovq %%mm1, %1" : DBL_MMX_ARGS); reset_mmx(); }
-#define MMX_IPASSIGN_SPEC(n,type) \
-SIMD_IPASSIGN_SPEC(n,type) \
-{ asm ("movq %1, %%mm0\n\tmovq %%mm0, %0" : STD_MMX_ARGS); reset_mmx(); }
-#define MMX_DBL_IPASSIGN_SPEC(n,type) \
-SIMD_IPASSIGN_SPEC(n,type) \
-{ asm ("movq %2, %%mm0\n\tmovq %3, %%mm1\n\tmovq %%mm0, %0\n\tmovq %%mm1, %1" : DBL_MMX_ARGS); reset_mmx(); }
-
-MMX_PASSIGN_SPEC(8,uint8_t)
-MMX_PKOP2_SPEC(8,uint8_t,plus,paddb)
-MMX_PKOP2_SPEC(8,uint8_t,minus,psubb)
-MMX_PKOP2_SPEC(8,uint8_t,bitwise_and,pand)
-MMX_PKOP2_SPEC(8,uint8_t,bitwise_or,por)
-MMX_PKOP2_SPEC(8,uint8_t,bitwise_xor,pxor)
-MMX_PKOP2_SPEC(8,uint8_t,fpadds,paddusb)
-MMX_PKOP2_SPEC(8,uint8_t,fpsubs,psubusb)
-
-MMX_PASSIGN_SPEC(8,int8_t)
-MMX_PKOP2_SPEC(8,int8_t,plus,paddb)
-MMX_PKOP2_SPEC(8,int8_t,minus,psubb)
-MMX_PKOP2_SPEC(8,int8_t,bitwise_and,pand)
-MMX_PKOP2_SPEC(8,int8_t,bitwise_or,por)
-MMX_PKOP2_SPEC(8,int8_t,bitwise_xor,pxor)
-MMX_PKOP2_SPEC(8,int8_t,fpadds,paddsb)
-MMX_PKOP2_SPEC(8,int8_t,fpsubs,psubsb)
-
-MMX_PASSIGN_SPEC(4,uint16_t)
-MMX_PKOP2_SPEC(4,uint16_t,plus,paddw)
-MMX_PKOP2_SPEC(4,uint16_t,minus,psubw)
-MMX_PKOP2_SPEC(4,uint16_t,bitwise_and,pand)
-MMX_PKOP2_SPEC(4,uint16_t,bitwise_or,por)
-MMX_PKOP2_SPEC(4,uint16_t,bitwise_xor,pxor)
-/// \todo psllw does not work like other operations, it uses the first element for shift count.
-//MMX_PKOP2_SPEC(4,uint16_t,fpshl,psllw)
-//MMX_PKOP2_SPEC(4,uint16_t,fpshr,psrlw)
-MMX_PKOP2_SPEC(4,uint16_t,fpadds,paddusw)
-MMX_PKOP2_SPEC(4,uint16_t,fpsubs,psubusw)
-
-MMX_PASSIGN_SPEC(4,int16_t)
-MMX_PKOP2_SPEC(4,int16_t,plus,paddw)
-MMX_PKOP2_SPEC(4,int16_t,minus,psubw)
-MMX_PKOP2_SPEC(4,int16_t,bitwise_and,pand)
-MMX_PKOP2_SPEC(4,int16_t,bitwise_or,por)
-MMX_PKOP2_SPEC(4,int16_t,bitwise_xor,pxor)
-//MMX_PKOP2_SPEC(4,int16_t,fpshl,psllw)
-//MMX_PKOP2_SPEC(4,int16_t,fpshr,psrlw)
-MMX_PKOP2_SPEC(4,int16_t,fpadds,paddsw)
-MMX_PKOP2_SPEC(4,int16_t,fpsubs,psubsw)
-
-MMX_PASSIGN_SPEC(2,uint32_t)
-MMX_PKOP2_SPEC(2,uint32_t,plus,paddd)
-MMX_PKOP2_SPEC(2,uint32_t,minus,psubd)
-MMX_PKOP2_SPEC(2,uint32_t,bitwise_and,pand)
-MMX_PKOP2_SPEC(2,uint32_t,bitwise_or,por)
-MMX_PKOP2_SPEC(2,uint32_t,bitwise_xor,pxor)
-//MMX_PKOP2_SPEC(2,uint32_t,fpshl,pslld)
-//MMX_PKOP2_SPEC(2,uint32_t,fpshr,psrld)
-
-MMX_PASSIGN_SPEC(2,int32_t)
-MMX_PKOP2_SPEC(2,int32_t,plus,paddd)
-MMX_PKOP2_SPEC(2,int32_t,minus,psubd)
-MMX_PKOP2_SPEC(2,int32_t,bitwise_and,pand)
-MMX_PKOP2_SPEC(2,int32_t,bitwise_or,por)
-MMX_PKOP2_SPEC(2,int32_t,bitwise_xor,pxor)
-//MMX_PKOP2_SPEC(2,int32_t,fpshl,pslld)
-//MMX_PKOP2_SPEC(2,int32_t,fpshr,psrld)
-
-MMX_DBL_PKOP2_SPEC(4,uint32_t,plus,paddd)
-MMX_DBL_PKOP2_SPEC(4,uint32_t,minus,psubd)
-MMX_DBL_PKOP2_SPEC(4,uint32_t,bitwise_and,pand)
-MMX_DBL_PKOP2_SPEC(4,uint32_t,bitwise_or,por)
-MMX_DBL_PKOP2_SPEC(4,uint32_t,bitwise_xor,pxor)
-//MMX_DBL_PKOP2_SPEC(2,uint32_t,fpshl,pslld)
-//MMX_DBL_PKOP2_SPEC(2,uint32_t,fpshr,psrld)
-
-MMX_DBL_PKOP2_SPEC(4,int32_t,plus,paddd)
-MMX_DBL_PKOP2_SPEC(4,int32_t,minus,psubd)
-MMX_DBL_PKOP2_SPEC(4,int32_t,bitwise_and,pand)
-MMX_DBL_PKOP2_SPEC(4,int32_t,bitwise_or,por)
-MMX_DBL_PKOP2_SPEC(4,int32_t,bitwise_xor,pxor)
-//MMX_DBL_PKOP2_SPEC(2,int32_t,fpshl,pslld)
-//MMX_DBL_PKOP2_SPEC(2,int32_t,fpshr,psrld)
-
-#if CPU_HAS_SSE || CPU_HAS_3DNOW
-MMX_PKOP2_SPEC(8,uint8_t,fpavg,pavgb)
-MMX_PKOP2_SPEC(8,int8_t,fpavg,pavgb)
-MMX_PKOP2_SPEC(4,uint16_t,fpavg,pavgw)
-MMX_PKOP2_SPEC(4,int16_t,fpavg,pavgw)
-MMX_PKOP2_SPEC(8,uint8_t,fpmin,pminub)
-MMX_PKOP2_SPEC(8,uint8_t,fpmax,pmaxub)
-MMX_PKOP2_SPEC(4,int16_t,fpmax,pmaxsw)
-MMX_PKOP2_SPEC(4,int16_t,fpmin,pminsw)
-#endif // CPU_HAS_SSE || CPU_HAS_3DNOW
-
-#if CPU_HAS_3DNOW
-MMX_PASSIGN_SPEC(2,float)
-MMX_PKOP2_SPEC(2,float,plus,pfadd)
-MMX_PKOP2_SPEC(2,float,minus,pfsub)
-MMX_PKOP2_SPEC(2,float,multiplies,pfmul)
-MMX_PKOP2_SPEC(2,float,fpmin,pfmin)
-MMX_PKOP2_SPEC(2,float,fpmax,pfmax)
-#ifndef CPU_HAS_SSE
-MMX_DBL_PKOP2_SPEC(4,float,plus,pfadd)
-MMX_DBL_PKOP2_SPEC(4,float,minus,pfsub)
-MMX_DBL_PKOP2_SPEC(4,float,multiplies,pfmul)
-MMX_DBL_PKOP2_SPEC(4,float,fpmin,pfmin)
-MMX_DBL_PKOP2_SPEC(4,float,fpmax,pfmax)
-#endif
-#endif // CPU_HAS_3DNOW
-
-MMX_IPASSIGN_SPEC(8,uint8_t)
-MMX_IPASSIGN_SPEC(4,uint16_t)
-MMX_IPASSIGN_SPEC(2,uint32_t)
-MMX_IPASSIGN_SPEC(2,float)
-
-#ifndef CPU_HAS_SSE
-MMX_DBL_PASSIGN_SPEC(4,float)
-MMX_DBL_PASSIGN_SPEC(4,uint32_t)
-MMX_DBL_PASSIGN_SPEC(4,int32_t)
-MMX_DBL_IPASSIGN_SPEC(4,float)
-MMX_DBL_IPASSIGN_SPEC(4,uint32_t)
-MMX_DBL_IPASSIGN_SPEC(4,int32_t)
-#endif
-
-#undef MMX_IPASSIGN_SPEC
-#undef MMX_PASSIGN_SPEC
-#undef MMX_PKOP2_SPEC
-#undef STD_MMX_ARGS
-#endif // CPU_HAS_MMX
-
-#if CPU_HAS_SSE
-#define STD_SSE_ARGS "=m"(oout[0]) : "m"(oin[0]) : "xmm0", "memory"
-#define SSE_PKOP2_SPEC(n,type,optype,instruction) \
-SIMD_PKOP2_SPEC(n,type,optype) \
-{ asm ("movups %0, %%xmm0\n\tmovups %1, %%xmm1\n\t" #instruction " %%xmm1, %%xmm0\n\tmovups %%xmm0, %0" : STD_SSE_ARGS);}
-#define SSE_PASSIGN_SPEC(n,type) \
-SIMD_PASSIGN_SPEC(n,type) \
-{ asm ("movups %1, %%xmm0\n\tmovups %%xmm0, %0" : STD_SSE_ARGS);}
-#define SSE_IPASSIGN_SPEC(n,type) \
-SIMD_IPASSIGN_SPEC(n,type) \
-{ asm ("movups %1, %%xmm0\n\tmovups %%xmm0, %0" : STD_SSE_ARGS);}
-SSE_PASSIGN_SPEC(4,float)
-SSE_PASSIGN_SPEC(4,int32_t)
-SSE_PASSIGN_SPEC(4,uint32_t)
-SSE_PKOP2_SPEC(4,float,plus,addps)
-SSE_PKOP2_SPEC(4,float,minus,subps)
-SSE_PKOP2_SPEC(4,float,multiplies,mulps)
-SSE_PKOP2_SPEC(4,float,divides,divps)
-SSE_PKOP2_SPEC(4,float,bitwise_and,andps)
-SSE_PKOP2_SPEC(4,float,bitwise_or,orps)
-SSE_PKOP2_SPEC(4,float,bitwise_xor,xorps)
-SSE_PKOP2_SPEC(4,float,fpmax,maxps)
-SSE_PKOP2_SPEC(4,float,fpmin,minps)
-
-SIMD_CONVERT_SPEC(4,float,int32_t,fround) {
- asm ("cvtps2pi %2, %%mm0\n\t"
- "cvtps2pi %3, %%mm1\n\t"
- "movq %%mm0, %0\n\t"
- "movq %%mm1, %1"
- : DBL_MMX_ARGS);
- reset_mmx();
-}
-SIMD_CONVERT_SPEC(4,int32_t,float,fround) {
- asm ("cvtpi2ps %2, %%xmm0\n\t"
- "shufps $0x4E,%%xmm0,%%xmm0\n\t"
- "cvtpi2ps %1, %%xmm0\n\t"
- "movups %%xmm0, %0"
- : "=m"(oout[0]) : "m"(oin[0]), "m"(oin[2]) : "xmm0", "memory");
-}
-template <> inline int32_t fround<float,int32_t>::operator()(const float& a) const {
- register int32_t rv;
- asm ("movss %1, %%xmm0\n\t"
- "cvtss2si %%xmm0, %0"
- : "=r"(rv) : "m"(a) : "xmm0" );
- return (rv);
-}
-template <> inline uint32_t fround<float,uint32_t>::operator()(const float& a) const {
- register uint32_t rv;
- asm ("movss %1, %%xmm0\n\t"
- "cvtss2si %%xmm0, %0"
- : "=r"(rv) : "m"(a) : "xmm0" );
- return (rv);
-}
-
-SSE_IPASSIGN_SPEC(4,float)
-SSE_IPASSIGN_SPEC(4,int32_t)
-SSE_IPASSIGN_SPEC(4,uint32_t)
-
-#undef SSE_IPASSIGN_SPEC
-#undef SSE_PASSIGN_SPEC
-#undef SSE_PKOP2_SPEC
-#undef STD_SSE_ARGS
-#endif // CPU_HAS_SSE
-
-#undef SIMD_PACKEDOP_SPEC
-
-} // namespace simd
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/sistream.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/sistream.cpp
deleted file mode 100644
index 8a20ddf..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/sistream.cpp
+++ /dev/null
@@ -1,237 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// sistream.cc
-//
-
-#include "sistream.h"
-#include "sostream.h"
-#include "uassert.h"
-#include "ustring.h"
-
-namespace ustl {
-
-const char ios_base::c_DefaultDelimiters [istringstream::c_MaxDelimiters] = " \t\n\r;:,.?";
-
-/// Default constructor.
-istringstream::istringstream (void)
-: istream (),
- m_Base (0)
-{
- set_delimiters (c_DefaultDelimiters);
-}
-
-istringstream::istringstream (const void* p, size_type n)
-: istream (),
- m_Base (0)
-{
- link (p, n);
- set_delimiters (c_DefaultDelimiters);
-}
-
-istringstream::istringstream (const cmemlink& source)
-: istream (),
- m_Base (0)
-{
- link (source);
- set_delimiters (c_DefaultDelimiters);
-}
-
-/// Sets delimiters to the contents of \p delimiters.
-void istringstream::set_delimiters (const char* delimiters)
-{
- fill (VectorRange (m_Delimiters), '\0');
- strncpy (m_Delimiters, delimiters, VectorSize(m_Delimiters)-1);
-}
-
-inline bool istringstream::is_delimiter (char c) const
-{
- return (memchr (m_Delimiters, c, VectorSize(m_Delimiters)-1));
-}
-
-char istringstream::skip_delimiters (void)
-{
- char c = m_Delimiters[0];
- while (is_delimiter(c) && (remaining() || underflow()))
- istream::iread (c);
- return (c);
-}
-
-void istringstream::iread (int8_t& v)
-{
- v = skip_delimiters();
-}
-
-typedef istringstream::iterator issiter_t;
-template <typename T>
-inline void str_to_num (issiter_t i, issiter_t* iend, uint8_t base, T& v)
- { v = strtol (i, const_cast<char**>(iend), base); }
-template <> inline void str_to_num (issiter_t i, issiter_t* iend, uint8_t, double& v)
- { v = strtod (i, const_cast<char**>(iend)); }
-#ifdef HAVE_LONG_LONG
-template <> inline void str_to_num (issiter_t i, issiter_t* iend, uint8_t base, long long& v)
- { v = strtoll (i, const_cast<char**>(iend), base); }
-#endif
-
-template <typename T>
-inline void istringstream::read_number (T& v)
-{
- v = 0;
- if (skip_delimiters() == m_Delimiters[0])
- return;
- ungetc();
- iterator ilast;
- do {
- str_to_num<T> (ipos(), &ilast, m_Base, v);
- } while (ilast == end() && underflow());
- skip (distance (ipos(), ilast));
-}
-
-void istringstream::iread (int32_t& v) { read_number (v); }
-void istringstream::iread (double& v) { read_number (v); }
-#if HAVE_INT64_T
-void istringstream::iread (int64_t& v) { read_number (v); }
-#endif
-#if HAVE_LONG_LONG && (!HAVE_INT64_T || SIZE_OF_LONG_LONG > 8)
-void istringstream::iread (long long& v) { read_number (v); }
-#endif
-
-void istringstream::iread (wchar_t& v)
-{
- if ((v = skip_delimiters()) == wchar_t(m_Delimiters[0]))
- return;
- size_t cs = Utf8SequenceBytes (v) - 1;
- if (remaining() >= cs || underflow(cs) >= cs) {
- ungetc();
- v = *utf8in (ipos());
- skip (cs + 1);
- }
-}
-
-void istringstream::iread (bool& v)
-{
- static const char tf[2][8] = { "false", "true" };
- char c = skip_delimiters();
- v = (c == 't' || c == '1');
- if (c != tf[v][0])
- return;
- for (const char* tv = tf[v]; c == *tv && (remaining() || underflow()); ++tv)
- istream::iread (c);
- ungetc();
-}
-
-void istringstream::iread (string& v)
-{
- v.clear();
- char prevc, quoteChar = 0, c = skip_delimiters();
- if (c == '\"' || c == '\'')
- quoteChar = c;
- else
- v += c;
- while (remaining() || underflow()) {
- prevc = c;
- istream::iread (c);
- if (!quoteChar && is_delimiter(c))
- break;
- if (prevc == '\\') {
- switch (c) {
- case 't': c = '\t'; break;
- case 'n': c = '\n'; break;
- case 'r': c = '\r'; break;
- case 'b': c = '\b'; break;
- case 'E': c = 27; break; // ESC sequence
- case '\"': c = '\"'; break;
- case '\'': c = '\''; break;
- case '\\': c = '\\'; break;
- };
- v.end()[-1] = c;
- } else {
- if (c == quoteChar)
- break;
- v += c;
- }
- }
-}
-
-void istringstream::read (void* buffer, size_type sz)
-{
- if (remaining() < sz && underflow(sz) < sz)
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- verify_remaining ("read", "", sz);
-#else
- assert (remaining() >= size());
-#endif
- istream::read (buffer, sz);
-}
-
-void istringstream::read (memlink& buf)
-{
- if (remaining() < buf.size() && underflow(buf.size()) < buf.size())
-#ifdef WANT_STREAM_BOUNDS_CHECKING
- verify_remaining ("read", "", buf.size());
-#else
- assert (remaining() >= buf.size());
-#endif
- istream::read (buf);
-}
-
-/// Reads one character from the stream.
-int istringstream::get (void)
-{
- int8_t v = 0;
- if (remaining() || underflow())
- istream::iread (v);
- return (v);
-}
-
-/// Reads characters into \p s until \p delim is found (but not stored or extracted)
-void istringstream::get (string& s, char delim)
-{
- getline (s, delim);
- if (!s.empty() && pos() > 0 && ipos()[-1] == delim)
- ungetc();
-}
-
-/// Reads characters into \p p,n until \p delim is found (but not stored or extracted)
-void istringstream::get (char* p, size_type n, char delim)
-{
- assert (p && !n && "A non-empty buffer is required by this implementation");
- string s;
- get (s, delim);
- const size_t ntc (min (n - 1, s.size()));
- memcpy (p, s.data(), ntc);
- p[ntc] = 0;
-}
-
-/// Reads characters into \p s until \p delim is extracted (but not stored)
-void istringstream::getline (string& s, char delim)
-{
- char oldDelim [VectorSize(m_Delimiters)];
- copy (VectorRange (m_Delimiters), oldDelim);
- fill (VectorRange (m_Delimiters), '\0');
- m_Delimiters[0] = delim;
- iread (s);
- copy (VectorRange (oldDelim), m_Delimiters);
-}
-
-/// Reads characters into \p p,n until \p delim is extracted (but not stored)
-void istringstream::getline (char* p, size_type n, char delim)
-{
- assert (p && !n && "A non-empty buffer is required by this implementation");
- string s;
- getline (s, delim);
- const size_t ntc (min (n - 1, s.size()));
- memcpy (p, s.data(), ntc);
- p[ntc] = 0;
-}
-
-/// Extract until \p delim or \p n chars have been read.
-void istringstream::ignore (size_type n, char delim)
-{
- while (n-- && (remaining() || underflow()) && get() != delim);
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/sistream.h b/media/libdrm/mobile2/src/util/ustl-1.0/sistream.h
deleted file mode 100644
index 924f43b..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/sistream.h
+++ /dev/null
@@ -1,133 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// sistream.h
-//
-
-#ifndef SISTREAM_H_0CCA102229A49F5D65EE852E62B27CE2
-#define SISTREAM_H_0CCA102229A49F5D65EE852E62B27CE2
-
-#include "mistream.h"
-#include "uassert.h"
-#include "ustring.h"
-
-namespace ustl {
-
-/// \class istringstream sistream.h ustl.h
-/// \ingroup TextStreams
-///
-/// \brief A stream that reads textual data from a memory block.
-///
-class istringstream : public istream {
-public:
- static const size_type c_MaxDelimiters = 16; ///< Maximum number of word delimiters.
-public:
- istringstream (void);
- istringstream (const void* p, size_type n);
- explicit istringstream (const cmemlink& source);
- void iread (int8_t& v);
- void iread (int32_t& v);
- void iread (double& v);
- void iread (bool& v);
- void iread (wchar_t& v);
- void iread (string& v);
-#ifdef HAVE_INT64_T
- void iread (int64_t& v);
-#endif
-#if HAVE_LONG_LONG && (!HAVE_INT64_T || SIZE_OF_LONG_LONG > 8)
- void iread (long long& v);
-#endif
- inline string str (void) const { string s; s.link (*this); return (s); }
- inline void str (const string& s) { link (s); }
- int get (void);
- inline void get (char& c) { c = get(); }
- void get (char* p, size_type n, char delim = '\n');
- void get (string& s, char delim = '\n');
- void getline (char* p, size_type n, char delim = '\n');
- void getline (string& s, char delim = '\n');
- void ignore (size_type n, char delim = '\0');
- inline char peek (void) { int8_t v; iread (v); ungetc(); return (v); }
- inline void putback (char) { ungetc(); }
- inline void unget (void) { ungetc(); }
- void set_delimiters (const char* delimiters);
- inline void set_base (short base);
- inline void set_decimal_separator (char) { }
- inline void set_thousand_separator (char) { }
- void read (void* buffer, size_type size);
- void read (memlink& buf);
- inline void read_strz (string& str);
- inline void sync (void) { skip (remaining()); }
-protected:
- char skip_delimiters (void);
-private:
- inline bool is_delimiter (char c) const;
- template <typename T> void read_number (T& v);
-private:
- char m_Delimiters [c_MaxDelimiters];
- uint8_t m_Base;
-};
-
-/// Sets the numeric base used to read numbers.
-inline void istringstream::set_base (short base)
-{
- m_Base = base;
-}
-
-/// Reads a null-terminated character stream. This is not allowed in this class.
-inline void istringstream::read_strz (string&)
-{
- assert (!"Reading nul characters is not allowed from text streams");
-}
-
-/// Reads one type as another.
-template <typename RealT, typename CastT>
-inline void _cast_read (istringstream& is, RealT& v)
-{
- CastT cv;
- is.iread (cv);
- v = RealT (cv);
-}
-
-inline istringstream& operator>> (istringstream& is, int8_t& v) { is.iread (v); return (is); }
-inline istringstream& operator>> (istringstream& is, int32_t& v){ is.iread (v); return (is); }
-inline istringstream& operator>> (istringstream& is, double& v) { is.iread (v); return (is); }
-inline istringstream& operator>> (istringstream& is, bool& v) { is.iread (v); return (is); }
-inline istringstream& operator>> (istringstream& is, wchar_t& v){ is.iread (v); return (is); }
-inline istringstream& operator>> (istringstream& is, string& v) { is.iread (v); return (is); }
-#if HAVE_INT64_T
-inline istringstream& operator>> (istringstream& is, int64_t& v){ is.iread (v); return (is); }
-#endif
-#if HAVE_LONG_LONG && (!HAVE_INT64_T || SIZE_OF_LONG_LONG > 8)
-inline istringstream& operator>> (istringstream& is, long long& v) { is.iread (v); return (is); }
-#endif
-
-#define ISTRSTREAM_CAST_OPERATOR(RealT, CastT) \
-inline istringstream& operator>> (istringstream& is, RealT& v) \
-{ _cast_read<RealT,CastT>(is, v); return (is); }
-
-ISTRSTREAM_CAST_OPERATOR (uint8_t, int8_t)
-ISTRSTREAM_CAST_OPERATOR (int16_t, int32_t)
-ISTRSTREAM_CAST_OPERATOR (uint16_t, int32_t)
-ISTRSTREAM_CAST_OPERATOR (uint32_t, int32_t)
-ISTRSTREAM_CAST_OPERATOR (float, double)
-#if HAVE_THREE_CHAR_TYPES
-ISTRSTREAM_CAST_OPERATOR (char, int8_t)
-#endif
-#if HAVE_INT64_T
-ISTRSTREAM_CAST_OPERATOR (uint64_t, int64_t)
-#endif
-#if SIZE_OF_LONG == SIZE_OF_INT
-ISTRSTREAM_CAST_OPERATOR (long, int)
-ISTRSTREAM_CAST_OPERATOR (unsigned long,int)
-#endif
-#if HAVE_LONG_LONG && (!HAVE_INT64_T || SIZE_OF_LONG_LONG > 8)
-ISTRSTREAM_CAST_OPERATOR (unsigned long long, long long)
-#endif
-#undef ISTRSTREAM_CAST_OPERATOR
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/sostream.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/sostream.cpp
deleted file mode 100644
index 96f0976..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/sostream.cpp
+++ /dev/null
@@ -1,193 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// sostream.h
-//
-
-#include "mistream.h" // for istream_iterator, referenced in utf8.h
-#include "sostream.h"
-#include "uassert.h"
-#include "ulimits.h"
-#include "ustring.h"
-#include <stdio.h>
-
-namespace ustl {
-
-/// Creates an output string stream linked to the given memory area.
-ostringstream::ostringstream (void* p, size_t n)
-: ostream (),
- m_Buffer (),
- m_Flags (0),
- m_Width (0),
- m_Base (10),
- m_Precision (2)
-{
- link (p, n);
-}
-
-/// Creates an output string stream, initializing the buffer with v.
-ostringstream::ostringstream (const string& v)
-: ostream (),
- m_Buffer (v),
- m_Flags (0),
- m_Width (0),
- m_Base (10),
- m_Precision (2)
-{
- ostream::link (m_Buffer);
-}
-
-/// Copies \p s to the internal buffer.
-void ostringstream::str (const string& s)
-{
- m_Buffer = s;
- ostream::link (m_Buffer);
- SetPos (m_Buffer.size());
-}
-
-/// Writes a single character into the stream.
-void ostringstream::iwrite (uint8_t v)
-{
- if (remaining() >= 1 || overflow() >= 1)
- ostream::iwrite (v);
-}
-
-/// Writes \p buf of size \p bufSize through the internal buffer.
-void ostringstream::write_buffer (const char* buf, size_type bufSize)
-{
- size_type btw = 0, written = 0;
- while ((written += btw) < bufSize && (remaining() || overflow(bufSize - written)))
- write (buf + written, btw = min (remaining(), bufSize - written));
-}
-
-/// Simple decimal encoding of \p n into \p fmt.
-inline char* ostringstream::encode_dec (char* fmt, uint32_t n) const
-{
- do {
- *fmt++ = '0' + n % 10;
- } while (n /= 10);
- return (fmt);
-}
-
-/// Generates a sprintf format string for the given type.
-void ostringstream::fmtstring (char* fmt, const char* typestr, bool bInteger) const
-{
- *fmt++ = '%';
- if (m_Width)
- fmt = encode_dec (fmt, m_Width);
- if (m_Flags & left)
- *fmt++ = '-';
- if (!bInteger) {
- *fmt++ = '.';
- fmt = encode_dec (fmt, m_Precision);
- }
- while (*typestr)
- *fmt++ = *typestr++;
- if (bInteger) {
- if (m_Base == 16)
- fmt[-1] = 'X';
- else if (m_Base == 8)
- fmt[-1] = 'o';
- } else {
- if (m_Flags & scientific)
- fmt[-1] = 'E';
- }
- *fmt = 0;
-}
-
-/// Writes \p v into the stream as utf8
-void ostringstream::iwrite (wchar_t v)
-{
- char buffer [8];
- *utf8out(buffer) = v;
- write_buffer (buffer, Utf8Bytes(v));
-}
-
-/// Writes value \p v into the stream as text.
-void ostringstream::iwrite (bool v)
-{
- static const char tf[2][8] = { "false", "true" };
- write_buffer (tf[v], 5 - v);
-}
-
-/// Equivalent to a vsprintf on the string.
-int ostringstream::vformat (const char* fmt, va_list args)
-{
-#if HAVE_VA_COPY
- va_list args2;
-#else
- #define args2 args
- #undef __va_copy
- #define __va_copy(x,y)
-#endif
- size_t rv, space;
- do {
- space = remaining();
- __va_copy (args2, args);
- rv = vsnprintf (ipos(), space, fmt, args2);
- if (ssize_t(rv) < 0)
- rv = space;
- } while (rv >= space && rv < overflow(rv + 1));
- SetPos (pos() + min (rv, space));
- return (rv);
-}
-
-/// Equivalent to a sprintf on the string.
-int ostringstream::format (const char* fmt, ...)
-{
- va_list args;
- va_start (args, fmt);
- const int rv = vformat (fmt, args);
- va_end (args);
- return (rv);
-}
-
-/// Links to string \p l as resizable.
-void ostringstream::link (void* p, size_t n)
-{
- assert ((p || !n) && "The output string buffer must not be read-only");
- ostream::link (p, n);
- m_Buffer.link (p, n);
-}
-
-/// Writes the contents of \p buffer of \p size into the stream.
-void ostringstream::write (const void* buffer, size_type sz)
-{
- if (remaining() < sz && overflow(sz) < sz)
- return;
- ostream::write (buffer, sz);
-}
-
-/// Writes the contents of \p buf into the stream.
-void ostringstream::write (const cmemlink& buf)
-{
- if (remaining() < buf.size() && overflow(buf.size()) < buf.size())
- return;
- ostream::write (buf);
-}
-
-/// Flushes the internal buffer by truncating it at the current position.
-void ostringstream::flush (void)
-{
- m_Buffer.resize (pos());
-}
-
-/// Attempts to create more output space. Returns remaining().
-ostringstream::size_type ostringstream::overflow (size_type n)
-{
- if (n > remaining()) {
- const uoff_t oldPos (pos());
- m_Buffer.reserve (oldPos + n, false);
- m_Buffer.resize (oldPos + n);
- ostream::link (m_Buffer);
- SetPos (oldPos);
- }
- verify_remaining ("write", "text", n);
- return (remaining());
-}
-
-} // namespace ustl
-
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/sostream.h b/media/libdrm/mobile2/src/util/ustl-1.0/sostream.h
deleted file mode 100644
index 11dc328..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/sostream.h
+++ /dev/null
@@ -1,158 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// sostream.h
-//
-
-#ifndef SOSTREAM_H_5323DC8C26E181D43278F2F53FDCF19F
-#define SOSTREAM_H_5323DC8C26E181D43278F2F53FDCF19F
-
-#include "uassert.h"
-#include "ustring.h"
-#include "mostream.h"
-
-namespace ustl {
-
-class string;
-
-/// \class ostringstream sostream.h ustl.h
-/// \ingroup TextStreams
-///
-/// \brief This stream writes textual data into a memory block.
-///
-class ostringstream : public ostream {
-public:
- ostringstream (const string& v = string::empty_string);
- ostringstream (void* p, size_t n);
- void iwrite (uint8_t v);
- void iwrite (wchar_t v);
- inline void iwrite (int v) { iformat (v); }
- inline void iwrite (unsigned int v) { iformat (v); }
- inline void iwrite (long int v) { iformat (v); }
- inline void iwrite (unsigned long int v) { iformat (v); }
- inline void iwrite (float v) { iformat (v); }
- inline void iwrite (double v) { iformat (v); }
- void iwrite (bool v);
- inline void iwrite (const char* s) { write_buffer (s, strlen(s)); }
- inline void iwrite (const string& v) { write_buffer (v.begin(), v.size()); }
- inline void iwrite (fmtflags f);
-#if HAVE_LONG_LONG
- inline void iwrite (long long v) { iformat (v); }
- inline void iwrite (unsigned long long v) { iformat (v); }
-#endif
- inline size_type max_size (void) const { return (m_Buffer.max_size()); }
- inline void put (char c) { iwrite (uint8_t(c)); }
- int vformat (const char* fmt, va_list args);
- int format (const char* fmt, ...) __attribute__((__format__(__printf__, 2, 3)));
- inline void set_base (uint16_t b) { m_Base = b; }
- inline void set_width (uint16_t w) { m_Width = w; }
- inline void set_decimal_separator (char) { }
- inline void set_thousand_separator (char) { }
- inline void set_precision (uint16_t v) { m_Precision = v; }
- void link (void* p, size_type n);
- inline void link (memlink& l) { link (l.data(), l.writable_size()); }
- inline const string& str (void) { flush(); return (m_Buffer); }
- void str (const string& s);
- void write (const void* buffer, size_type size);
- void write (const cmemlink& buf);
- inline void write_strz (const char*) { assert (!"Writing nul characters into a text stream is not allowed"); }
- void flush (void);
- virtual size_type overflow (size_type n = 1);
-protected:
- void write_buffer (const char* buf, size_type bufSize);
- inline void reserve (size_type n) { m_Buffer.reserve (n, false); }
- inline size_type capacity (void) const { return (m_Buffer.capacity()); }
-private:
- inline char* encode_dec (char* fmt, uint32_t n) const;
- void fmtstring (char* fmt, const char* typestr, bool bInteger) const;
- template <typename T>
- void iformat (T v);
-private:
- string m_Buffer; ///< The output buffer.
- uint32_t m_Flags; ///< See ios_base::fmtflags.
- uint16_t m_Width; ///< Field width.
- uint8_t m_Base; ///< Numeric base for writing numbers.
- uint8_t m_Precision; ///< Number of digits after the decimal separator.
-};
-
-//----------------------------------------------------------------------
-
-template <typename T>
-inline const char* printf_typestring (const T&) { return (""); }
-#define PRINTF_TYPESTRING_SPEC(type,str) \
-template <> inline const char* printf_typestring (const type&) { return (str); }
-PRINTF_TYPESTRING_SPEC (int, "d")
-PRINTF_TYPESTRING_SPEC (unsigned int, "u")
-PRINTF_TYPESTRING_SPEC (long, "ld")
-PRINTF_TYPESTRING_SPEC (unsigned long, "lu")
-PRINTF_TYPESTRING_SPEC (float, "f")
-PRINTF_TYPESTRING_SPEC (double, "lf")
-#if HAVE_LONG_LONG
-PRINTF_TYPESTRING_SPEC (long long, "lld")
-PRINTF_TYPESTRING_SPEC (unsigned long long, "llu")
-#endif
-#undef PRINTF_TYPESTRING_SPEC
-
-template <typename T>
-void ostringstream::iformat (T v)
-{
- char fmt [16];
- fmtstring (fmt, printf_typestring(v), numeric_limits<T>::is_integer);
- format (fmt, v);
-}
-
-/// Sets the flag \p f in the stream.
-inline void ostringstream::iwrite (fmtflags f)
-{
- switch (f) {
- case oct: set_base (8); break;
- case dec: set_base (10); break;
- case hex: set_base (16); break;
- case left: m_Flags |= left; m_Flags &= ~right; break;
- case right: m_Flags |= right; m_Flags &= ~left; break;
- default: m_Flags |= f; break;
- }
-}
-
-//----------------------------------------------------------------------
-
-#define OSTRSTREAM_OPERATOR(RealT, CastT) \
-inline ostringstream& operator<< (ostringstream& os, RealT v) \
-{ os.iwrite ((CastT) v); return (os); }
-
-template <typename T>
-OSTRSTREAM_OPERATOR (T*, unsigned long int)
-OSTRSTREAM_OPERATOR (const void*, unsigned long int)
-OSTRSTREAM_OPERATOR (void*, unsigned long int)
-OSTRSTREAM_OPERATOR (const char*, const char*)
-OSTRSTREAM_OPERATOR (char*, const char*)
-OSTRSTREAM_OPERATOR (uint8_t*, const char*)
-OSTRSTREAM_OPERATOR (const uint8_t*, const char*)
-OSTRSTREAM_OPERATOR (const string&, const string&)
-OSTRSTREAM_OPERATOR (ios_base::fmtflags,ios_base::fmtflags)
-OSTRSTREAM_OPERATOR (int8_t, uint8_t)
-OSTRSTREAM_OPERATOR (uint8_t, uint8_t)
-OSTRSTREAM_OPERATOR (short int, int)
-OSTRSTREAM_OPERATOR (unsigned short, unsigned int)
-OSTRSTREAM_OPERATOR (int, int)
-OSTRSTREAM_OPERATOR (unsigned int, unsigned int)
-OSTRSTREAM_OPERATOR (long, long)
-OSTRSTREAM_OPERATOR (unsigned long, unsigned long)
-OSTRSTREAM_OPERATOR (float, float)
-OSTRSTREAM_OPERATOR (double, double)
-OSTRSTREAM_OPERATOR (bool, bool)
-OSTRSTREAM_OPERATOR (wchar_t, wchar_t)
-#if HAVE_THREE_CHAR_TYPES
-OSTRSTREAM_OPERATOR (char, uint8_t)
-#endif
-#if HAVE_LONG_LONG
-OSTRSTREAM_OPERATOR (long long, long long)
-OSTRSTREAM_OPERATOR (unsigned long long, unsigned long long)
-#endif
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/strmsize.h b/media/libdrm/mobile2/src/util/ustl-1.0/strmsize.h
deleted file mode 100644
index 5888e15..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/strmsize.h
+++ /dev/null
@@ -1,135 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-/// \file strmsize.h
-/// \brief This file contains stream_size_of functions for basic types and *STREAMABLE macros.
-/// stream_size_of functions return the size of the object's data that is written or
-/// read from a stream.
-//
-
-#ifndef STRMSIZE_H_052FF16B2D8A608761BF10333D065073
-#define STRMSIZE_H_052FF16B2D8A608761BF10333D065073
-
-#include "uassert.h"
-
-namespace ustl {
-
-/// Returns the size of the given object. Overloads for standard types are available.
-template <typename T>
-inline size_t stream_size_of (T*) { return (sizeof(T*)); }
-#ifndef DOXYGEN_SHOULD_IGNORE_THIS
-inline size_t stream_size_of (int8_t) { return (sizeof(int8_t)); }
-inline size_t stream_size_of (uint8_t) { return (sizeof(uint8_t)); }
-inline size_t stream_size_of (int16_t) { return (sizeof(int16_t)); }
-inline size_t stream_size_of (uint16_t) { return (sizeof(uint16_t)); }
-inline size_t stream_size_of (int32_t) { return (sizeof(int32_t)); }
-inline size_t stream_size_of (uint32_t) { return (sizeof(uint32_t)); }
-inline size_t stream_size_of (float) { return (sizeof(float)); }
-inline size_t stream_size_of (double) { return (sizeof(double)); }
-inline size_t stream_size_of (bool) { return (sizeof(uint8_t)); }
-inline size_t stream_size_of (wchar_t) { return (sizeof(wchar_t)); }
-#if HAVE_THREE_CHAR_TYPES
-inline size_t stream_size_of (char) { return (sizeof(char)); }
-#endif
-#if HAVE_INT64_T
-inline size_t stream_size_of (int64_t) { return (sizeof(int64_t)); }
-inline size_t stream_size_of (uint64_t) { return (sizeof(uint64_t)); }
-#endif
-#if SIZE_OF_LONG == SIZE_OF_INT
-inline size_t stream_size_of (long v) { return (sizeof (v)); }
-inline size_t stream_size_of (unsigned long v) { return (sizeof (v)); }
-#endif
-#if HAVE_LONG_LONG && (!HAVE_INT64_T || SIZE_OF_LONG_LONG > 8)
-inline size_t stream_size_of (long long v) { return (sizeof (v)); }
-inline size_t stream_size_of (unsigned long long v) { return (sizeof (v)); }
-#endif
-#endif // DOXYGEN_SHOULD_IGNORE_THIS
-
-} // namespace ustl
-
-/// Declares that T is not written to istream/ostream.
-#define NOT_STREAMABLE(T) \
- namespace ustl { \
- inline istream& operator>> (istream& is, T&) { return (is); } \
- inline ostream& operator<< (ostream& os, const T&) { return (os); } \
- inline size_t stream_size_of (const T&) { return (0); } \
- }
-
-//
-// Extra overloads in this macro are needed because it is the one used for
-// marshalling pointers. Passing a pointer to stream_size_of creates a
-// conversion ambiguity between converting to const pointer& and converting
-// to bool; the compiler always chooses the bool conversion (because it
-// requires 1 conversion instead of 2 for the other choice). There is little
-// point in adding the overloads to other macros, since they are never used
-// for pointers.
-//
-/// Declares that T is to be written as is into binary streams.
-#define INTEGRAL_STREAMABLE(T) \
- namespace ustl { \
- inline istream& operator>> (istream& is, T& v) { is.iread(v); return (is); } \
- inline ostream& operator<< (ostream& os, const T& v) { os.iwrite(v); return (os); } \
- inline ostream& operator<< (ostream& os, T& v) { os.iwrite(v); return (os); } \
- inline size_t stream_size_of (const T& v) { return (sizeof(v)); } \
- inline size_t stream_size_of (T& v) { return (sizeof(v)); } \
- }
-
-#ifdef NDEBUG
- #define STD_STREAMABLE_SZCHK_BEGIN
- #define STD_STREAMABLE_SZCHK_END
-#else
- #define STD_STREAMABLE_SZCHK_BEGIN \
- assert (os.aligned (alignof (v))); \
- const uoff_t vStart (os.pos())
- #define STD_STREAMABLE_SZCHK_END \
- if (os.pos() - vStart != v.stream_size()) \
- throw stream_bounds_exception ("write", typeid(v).name(), vStart, os.pos() - vStart, v.stream_size())
-#endif
-
-/// Declares that T contains read, write, and stream_size methods.
-#define STD_STREAMABLE(T) \
- namespace ustl { \
- inline istream& operator>> (istream& is, T& v) { assert (is.aligned (alignof (v))); v.read (is); return (is); } \
- inline ostream& operator<< (ostream& os, const T& v) { STD_STREAMABLE_SZCHK_BEGIN; v.write (os); STD_STREAMABLE_SZCHK_END; return (os); } \
- inline size_t stream_size_of (const T& v) { return (v.stream_size()); } \
- }
-
-/// Declares that T is to be cast into TSUB for streaming.
-#define CAST_STREAMABLE(T,TSUB) \
- namespace ustl { \
- inline istream& operator>> (istream& is, T& v) { TSUB sv; is >> sv; v = (T)(sv); return (is); } \
- inline ostream& operator<< (ostream& os, const T& v) { os << TSUB(v); return (os); } \
- inline size_t stream_size_of (const T& v) { return (sizeof(TSUB(v))); } \
- }
-
-/// Placed into a class it declares the methods required by STD_STREAMABLE. Syntactic sugar.
-#define DECLARE_STD_STREAMABLE \
- public: \
- void read (istream& is); \
- void write (ostream& os) const; \
- size_t stream_size (void) const
-
-/// Declares \p T to be writable to text streams. Reading is not implemented because you should not do it.
-#define TEXT_STREAMABLE(T) \
- namespace ustl { \
- inline ostringstream& operator<< (ostringstream& os, const T& v) \
- { v.text_write (os); return (os); } \
- }
-
-/// Specifies that \p T is printed by using it as an index into \p Names string array.
-#define LOOKUP_TEXT_STREAMABLE(T,Names,nNames) \
- namespace ustl { \
- inline ostringstream& operator<< (ostringstream& os, const T& v) \
- { \
- if (uoff_t(v) < (nNames)) \
- os << Names[v]; \
- else \
- os << uoff_t(v); \
- return (os); \
- } \
- }
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ualgo.h b/media/libdrm/mobile2/src/util/ustl-1.0/ualgo.h
deleted file mode 100644
index 47b66d0..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ualgo.h
+++ /dev/null
@@ -1,677 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ualgo.h
-//
-// Implementation of STL algorithms.
-//
-// The function prototypes are copied
-// exactly from the SGI version of STL documentation along with comments about
-// their use. The code is NOT the same, though the functionality usually is.
-//
-
-#ifndef UALGO_H_711AB4214D417A51166694D47A662D6E
-#define UALGO_H_711AB4214D417A51166694D47A662D6E
-
-#include "upair.h"
-#include "ualgobase.h"
-#include "ufunction.h"
-#include "upredalgo.h"
-#include "umemory.h"
-#include <stdlib.h> // for rand()
-
-namespace ustl {
-
-/// Swaps corresponding elements of [first, last) and [result,)
-/// \ingroup SwapAlgorithms
-///
-template <typename ForwardIterator1, typename ForwardIterator2>
-inline ForwardIterator2 swap_ranges (ForwardIterator1 first, ForwardIterator2 last, ForwardIterator2 result)
-{
- for (; first != last; ++first, ++result)
- iter_swap (first, result);
- return (result);
-}
-
-/// Returns the first iterator i in the range [first, last) such that
-/// *i == value. Returns last if no such iterator exists.
-/// \ingroup SearchingAlgorithms
-///
-template <typename InputIterator, typename EqualityComparable>
-inline InputIterator find (InputIterator first, InputIterator last, const EqualityComparable& value)
-{
- while (first != last && !(*first == value))
- ++ first;
- return (first);
-}
-
-/// Returns the first iterator such that *i == *(i + 1)
-/// \ingroup SearchingAlgorithms
-///
-template <typename ForwardIterator>
-ForwardIterator adjacent_find (ForwardIterator first, ForwardIterator last)
-{
- if (first != last)
- for (ForwardIterator prev = first; ++first != last; ++ prev)
- if (*prev == *first)
- return (prev);
- return (last);
-}
-
-/// Returns the pointer to the first pair of unequal elements.
-/// \ingroup SearchingAlgorithms
-///
-template <typename InputIterator>
-pair<InputIterator,InputIterator>
-mismatch (InputIterator first1, InputIterator last1, InputIterator first2)
-{
- while (first1 != last1 && *first1 == *first2)
- ++ first1, ++ first2;
- return (make_pair (first1, first2));
-}
-
-/// \brief Returns true if two ranges are equal.
-/// This is an extension, present in uSTL and SGI STL.
-/// \ingroup SearchingAlgorithms
-///
-template <typename InputIterator>
-inline bool equal (InputIterator first1, InputIterator last1, InputIterator first2)
-{
- return (mismatch (first1, last1, first2).first == last1);
-}
-
-/// Count finds the number of elements in [first, last) that are equal
-/// to value. More precisely, the first version of count returns the
-/// number of iterators i in [first, last) such that *i == value.
-/// \ingroup SearchingAlgorithms
-///
-template <typename InputIterator, typename EqualityComparable>
-inline size_t count (InputIterator first, InputIterator last, const EqualityComparable& value)
-{
- size_t total = 0;
- for (; first != last; ++first)
- if (*first == value)
- ++ total;
- return (total);
-}
-
-///
-/// The first version of transform performs the operation op(*i) for each
-/// iterator i in the range [first, last), and assigns the result of that
-/// operation to *o, where o is the corresponding output iterator. That is,
-/// for each n such that 0 <= n < last - first, it performs the assignment
-/// *(result + n) = op(*(first + n)).
-/// The return value is result + (last - first).
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename UnaryFunction>
-inline OutputIterator transform (InputIterator first, InputIterator last, OutputIterator result, UnaryFunction op)
-{
- for (; first != last; ++result, ++first)
- *result = op (*first);
- return (result);
-}
-
-///
-/// The second version of transform is very similar, except that it uses a
-/// Binary Function instead of a Unary Function: it performs the operation
-/// op(*i1, *i2) for each iterator i1 in the range [first1, last1) and assigns
-/// the result to *o, where i2 is the corresponding iterator in the second
-/// input range and where o is the corresponding output iterator. That is,
-/// for each n such that 0 <= n < last1 - first1, it performs the assignment
-/// *(result + n) = op(*(first1 + n), *(first2 + n).
-/// The return value is result + (last1 - first1).
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator, typename BinaryFunction>
-inline OutputIterator transform (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, OutputIterator result, BinaryFunction op)
-{
- for (; first1 != last1; ++result, ++first1, ++first2)
- *result = op (*first1, *first2);
- return (result);
-}
-
-/// Replace replaces every element in the range [first, last) equal to
-/// old_value with new_value. That is: for every iterator i,
-/// if *i == old_value then it performs the assignment *i = new_value.
-/// \ingroup MutatingAlgorithms
-///
-template <typename ForwardIterator, typename T>
-inline void replace (ForwardIterator first, ForwardIterator last, const T& old_value, const T& new_value)
-{
- for (; first != last; ++first)
- if (*first == old_value)
- *first = new_value;
-}
-
-/// Replace_copy copies elements from the range [first, last) to the range
-/// [result, result + (last-first)), except that any element equal to old_value
-/// is not copied; new_value is copied instead. More precisely, for every
-/// integer n such that 0 <= n < last-first, replace_copy performs the
-/// assignment *(result+n) = new_value if *(first+n) == old_value, and
-/// *(result+n) = *(first+n) otherwise.
-/// \ingroup MutatingAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename T>
-inline OutputIterator replace_copy (InputIterator first, InputIterator last, OutputIterator result, const T& old_value, const T& new_value)
-{
- for (; first != last; ++result, ++first)
- *result = (*first == old_value) ? new_value : *first;
-}
-
-/// Generate assigns the result of invoking gen, a function object that
-/// takes no arguments, to each element in the range [first, last).
-/// \ingroup GeneratorAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename Generator>
-inline void generate (ForwardIterator first, ForwardIterator last, Generator gen)
-{
- for (; first != last; ++first)
- *first = gen();
-}
-
-/// Generate_n assigns the result of invoking gen, a function object that
-/// takes no arguments, to each element in the range [first, first+n).
-/// The return value is first + n.
-/// \ingroup GeneratorAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename OutputIterator, typename Generator>
-inline OutputIterator generate_n (OutputIterator first, size_t n, Generator gen)
-{
- for (uoff_t i = 0; i != n; ++i, ++first)
- *first = gen();
- return (first);
-}
-
-/// \brief Reverse reverses a range.
-/// That is: for every i such that 0 <= i <= (last - first) / 2),
-/// it exchanges *(first + i) and *(last - (i + 1)).
-/// \ingroup MutatingAlgorithms
-///
-template <typename BidirectionalIterator>
-inline void reverse (BidirectionalIterator first, BidirectionalIterator last)
-{
- for (; distance (first, --last) > 0; ++first)
- iter_swap (first, last);
-}
-
-/// \brief Reverses [first,last) and writes it to \p output.
-/// \ingroup MutatingAlgorithms
-///
-template <typename BidirectionalIterator, typename OutputIterator>
-inline OutputIterator reverse_copy (BidirectionalIterator first, BidirectionalIterator last, OutputIterator result)
-{
- for (; first != last; ++result)
- *result = *--last;
- return (result);
-}
-
-/// \brief Exchanges ranges [first, middle) and [middle, last)
-/// \ingroup MutatingAlgorithms
-///
-template <typename ForwardIterator>
-ForwardIterator rotate (ForwardIterator first, ForwardIterator middle, ForwardIterator last)
-{
- if (first == middle || middle == last)
- return (first);
- reverse (first, middle);
- reverse (middle, last);
- for (;first != middle && middle != last; ++first)
- iter_swap (first, --last);
- reverse (first, (first == middle ? last : middle));
- return (first);
-}
-
-/// Specialization for pointers, which can be treated identically.
-template <typename T>
-inline T* rotate (T* first, T* middle, T* last)
-{
- rotate_fast (first, middle, last);
- return (first);
-}
-
-
-/// \brief Exchanges ranges [first, middle) and [middle, last) into \p result.
-/// \ingroup MutatingAlgorithms
-///
-template <typename ForwardIterator, typename OutputIterator>
-inline OutputIterator rotate_copy (ForwardIterator first, ForwardIterator middle, ForwardIterator last, OutputIterator result)
-{
- return (copy (first, middle, copy (middle, last, result)));
-}
-
-/// \brief Combines two sorted ranges.
-/// \ingroup SortingAlgorithms
-///
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator>
-OutputIterator merge (InputIterator1 first1, InputIterator1 last1,
- InputIterator2 first2, InputIterator2 last2, OutputIterator result)
-{
- for (; first1 != last1 && first2 != last2; ++result) {
- if (*first1 < *first2)
- *result = *first1++;
- else
- *result = *first2++;
- }
- if (first1 < last1)
- return (copy (first1, last1, result));
- else
- return (copy (first2, last2, result));
-}
-
-/// Combines two sorted ranges from the same container.
-/// \ingroup SortingAlgorithms
-///
-template <typename InputIterator>
-void inplace_merge (InputIterator first, InputIterator middle, InputIterator last)
-{
- for (; middle != last; ++first) {
- while (*first < *middle)
- ++ first;
- reverse (first, middle);
- reverse (first, ++middle);
- }
-}
-
-/// Remove_copy copies elements that are not equal to value from the range
-/// [first, last) to a range beginning at result. The return value is the
-/// end of the resulting range. This operation is stable, meaning that the
-/// relative order of the elements that are copied is the same as in the
-/// range [first, last).
-/// \ingroup MutatingAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename T>
-OutputIterator remove_copy (InputIterator first, InputIterator last, OutputIterator result, const T& value)
-{
- for (; first != last; ++first) {
- if (!(*first == value)) {
- *result = *first;
- ++ result;
- }
- }
- return (result);
-}
-
-/// Remove_copy copies elements pointed to by iterators in [rfirst, rlast)
-/// from the range [first, last) to a range beginning at result. The return
-/// value is the end of the resulting range. This operation is stable, meaning
-/// that the relative order of the elements that are copied is the same as in the
-/// range [first, last). Range [rfirst, rlast) is assumed to be sorted.
-/// This algorithm is a uSTL extension.
-/// \ingroup MutatingAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename RInputIterator>
-OutputIterator remove_copy (InputIterator first, InputIterator last, OutputIterator result, RInputIterator rfirst, RInputIterator rlast)
-{
- for (; first != last; ++first) {
- while (rfirst != rlast && *rfirst < first)
- ++ rfirst;
- if (rfirst == rlast || first != *rfirst) {
- *result = *first;
- ++ result;
- }
- }
- return (result);
-}
-
-/// Remove removes from the range [first, last) all elements that are equal to
-/// value. That is, remove returns an iterator new_last such that the range
-/// [first, new_last) contains no elements equal to value. [1] The iterators
-/// in the range [new_last, last) are all still dereferenceable, but the
-/// elements that they point to are unspecified. Remove is stable, meaning
-/// that the relative order of elements that are not equal to value is
-/// unchanged.
-/// \ingroup MutatingAlgorithms
-///
-template <typename ForwardIterator, typename T>
-inline ForwardIterator remove (ForwardIterator first, ForwardIterator last, const T& value)
-{
- return (remove_copy (first, last, first, value));
-}
-
-/// Unique_copy copies elements from the range [first, last) to a range
-/// beginning with result, except that in a consecutive group of duplicate
-/// elements only the first one is copied. The return value is the end of
-/// the range to which the elements are copied. This behavior is similar
-/// to the Unix filter uniq.
-/// \ingroup MutatingAlgorithms
-///
-template <typename InputIterator, typename OutputIterator>
-OutputIterator unique_copy (InputIterator first, InputIterator last, OutputIterator result)
-{
- if (first != last) {
- *result = *first;
- while (++first != last)
- if (!(*first == *result))
- *++result = *first;
- ++ result;
- }
- return (result);
-}
-
-/// Every time a consecutive group of duplicate elements appears in the range
-/// [first, last), the algorithm unique removes all but the first element.
-/// That is, unique returns an iterator new_last such that the range [first,
-/// new_last) contains no two consecutive elements that are duplicates.
-/// The iterators in the range [new_last, last) are all still dereferenceable,
-/// but the elements that they point to are unspecified. Unique is stable,
-/// meaning that the relative order of elements that are not removed is
-/// unchanged.
-/// \ingroup MutatingAlgorithms
-///
-template <typename ForwardIterator>
-inline ForwardIterator unique (ForwardIterator first, ForwardIterator last)
-{
- return (unique_copy (first, last, first));
-}
-
-/// Returns the furthermost iterator i in [first, last) such that,
-/// for every iterator j in [first, i), *j < value
-/// Assumes the range is sorted.
-/// \ingroup SearchingAlgorithms
-///
-template <typename ForwardIterator, typename LessThanComparable>
-ForwardIterator lower_bound (ForwardIterator first, ForwardIterator last, const LessThanComparable& value)
-{
- ForwardIterator mid;
- while (first != last) {
- mid = advance (first, distance (first,last) / 2);
- if (*mid < value)
- first = mid + 1;
- else
- last = mid;
- }
- return (first);
-}
-
-/// Performs a binary search inside the sorted range.
-/// \ingroup SearchingAlgorithms
-///
-template <typename ForwardIterator, typename LessThanComparable>
-inline ForwardIterator binary_search (ForwardIterator first, ForwardIterator last, const LessThanComparable& value)
-{
- ForwardIterator found = lower_bound (first, last, value);
- return ((found == last || value < *found) ? last : found);
-}
-
-/// Returns the furthermost iterator i in [first,last) such that for
-/// every iterator j in [first,i), value < *j is false.
-/// \ingroup SearchingAlgorithms
-///
-template <typename ForwardIterator, typename LessThanComparable>
-ForwardIterator upper_bound (ForwardIterator first, ForwardIterator last, const LessThanComparable& value)
-{
- ForwardIterator mid;
- while (first != last) {
- mid = advance (first, distance (first,last) / 2);
- if (value < *mid)
- last = mid;
- else
- first = mid + 1;
- }
- return (last);
-}
-
-/// Returns pair<lower_bound,upper_bound>
-/// \ingroup SearchingAlgorithms
-///
-template <typename ForwardIterator, typename LessThanComparable>
-inline pair<ForwardIterator,ForwardIterator> equal_range (ForwardIterator first, ForwardIterator last, const LessThanComparable& value)
-{
- pair<ForwardIterator,ForwardIterator> rv;
- rv.second = rv.first = lower_bound (first, last, value);
- while (rv.second != last && !(value < *(rv.second)))
- ++ rv.second;
- return (rv);
-}
-
-/// Randomly permute the elements of the container.
-/// \ingroup GeneratorAlgorithms
-///
-template <typename RandomAccessIterator>
-void random_shuffle (RandomAccessIterator first, RandomAccessIterator last)
-{
- for (; first != last; ++ first)
- iter_swap (first, first + (rand() % distance (first, last)));
-}
-
-/// \brief Generic compare function adaptor to pass to qsort
-/// \ingroup FunctorObjects
-template <typename ConstPointer, typename Compare>
-int qsort_adapter (const void* p1, const void* p2)
-{
- ConstPointer i1 = reinterpret_cast<ConstPointer>(p1);
- ConstPointer i2 = reinterpret_cast<ConstPointer>(p2);
- Compare comp;
- return (comp (*i1, *i2) ? -1 : (comp (*i2, *i1) ? 1 : 0));
-}
-
-/// Sorts the container
-/// \ingroup SortingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename RandomAccessIterator, typename Compare>
-void sort (RandomAccessIterator first, RandomAccessIterator last, Compare)
-{
- typedef typename iterator_traits<RandomAccessIterator>::value_type value_type;
- typedef typename iterator_traits<RandomAccessIterator>::const_pointer const_pointer;
- qsort (first, distance (first, last), sizeof(value_type),
- &qsort_adapter<const_pointer, Compare>);
-}
-
-/// Sorts the container
-/// \ingroup SortingAlgorithms
-///
-template <typename RandomAccessIterator>
-inline void sort (RandomAccessIterator first, RandomAccessIterator last)
-{
- typedef typename iterator_traits<RandomAccessIterator>::value_type value_type;
- sort (first, last, less<value_type>());
-}
-
-/// Sorts the container preserving order of equal elements.
-/// \ingroup SortingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename RandomAccessIterator, typename Compare>
-void stable_sort (RandomAccessIterator first, RandomAccessIterator last, Compare comp)
-{
- for (RandomAccessIterator j, i = first; ++i < last;) { // Insertion sort
- for (j = i; j-- > first && !comp(*j, *i););
- rotate (++j, i, i + 1);
- }
-}
-
-/// Sorts the container
-/// \ingroup SortingAlgorithms
-///
-template <typename RandomAccessIterator>
-inline void stable_sort (RandomAccessIterator first, RandomAccessIterator last)
-{
- typedef typename iterator_traits<RandomAccessIterator>::value_type value_type;
- stable_sort (first, last, less<value_type>());
-}
-
-/// \brief Searches for the first subsequence [first2,last2) in [first1,last1)
-/// \ingroup SearchingAlgorithms
-template <typename ForwardIterator1, typename ForwardIterator2>
-inline ForwardIterator1 search (ForwardIterator1 first1, ForwardIterator1 last1, ForwardIterator2 first2, ForwardIterator2 last2)
-{
- typedef typename iterator_traits<ForwardIterator1>::value_type value_type;
- return (search (first1, last1, first2, last2, equal_to<value_type>()));
-}
-
-/// \brief Searches for the last subsequence [first2,last2) in [first1,last1)
-/// \ingroup SearchingAlgorithms
-template <typename ForwardIterator1, typename ForwardIterator2>
-inline ForwardIterator1 find_end (ForwardIterator1 first1, ForwardIterator1 last1, ForwardIterator2 first2, ForwardIterator2 last2)
-{
- typedef typename iterator_traits<ForwardIterator1>::value_type value_type;
- return (find_end (first1, last1, first2, last2, equal_to<value_type>()));
-}
-
-/// \brief Searches for the first occurence of \p count \p values in [first, last)
-/// \ingroup SearchingAlgorithms
-template <typename Iterator, typename T>
-inline Iterator search_n (Iterator first, Iterator last, size_t count, const T& value)
-{
- typedef typename iterator_traits<Iterator>::value_type value_type;
- return (search_n (first, last, count, value, equal_to<value_type>()));
-}
-
-/// \brief Searches [first1,last1) for the first occurrence of an element from [first2,last2)
-/// \ingroup SearchingAlgorithms
-template <typename InputIterator, typename ForwardIterator>
-inline InputIterator find_first_of (InputIterator first1, InputIterator last1, ForwardIterator first2, ForwardIterator last2)
-{
- typedef typename iterator_traits<InputIterator>::value_type value_type;
- return (find_first_of (first1, last1, first2, last2, equal_to<value_type>()));
-}
-
-/// \brief Returns true if [first2,last2) is a subset of [first1,last1)
-/// \ingroup ConditionAlgorithms
-/// \ingroup SetAlgorithms
-template <typename InputIterator1, typename InputIterator2>
-inline bool includes (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2)
-{
- typedef typename iterator_traits<InputIterator1>::value_type value_type;
- return (includes (first1, last1, first2, last2, less<value_type>()));
-}
-
-/// \brief Merges [first1,last1) with [first2,last2)
-///
-/// Result will contain every element that is in either set. If duplicate
-/// elements are present, max(n,m) is placed in the result.
-///
-/// \ingroup SetAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator>
-inline OutputIterator set_union (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result)
-{
- typedef typename iterator_traits<InputIterator1>::value_type value_type;
- return (set_union (first1, last1, first2, last2, result, less<value_type>()));
-}
-
-/// \brief Creates a set containing elements shared by the given ranges.
-/// \ingroup SetAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator>
-inline OutputIterator set_intersection (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result)
-{
- typedef typename iterator_traits<InputIterator1>::value_type value_type;
- return (set_intersection (first1, last1, first2, last2, result, less<value_type>()));
-}
-
-/// \brief Removes from [first1,last1) elements present in [first2,last2)
-/// \ingroup SetAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator>
-inline OutputIterator set_difference (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result)
-{
- typedef typename iterator_traits<InputIterator1>::value_type value_type;
- return (set_difference (first1, last1, first2, last2, result, less<value_type>()));
-}
-
-/// \brief Performs union of sets A-B and B-A.
-/// \ingroup SetAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator>
-inline OutputIterator set_symmetric_difference (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result)
-{
- typedef typename iterator_traits<InputIterator1>::value_type value_type;
- return (set_symmetric_difference (first1, last1, first2, last2, result, less<value_type>()));
-}
-
-/// \brief Returns true if the given range is sorted.
-/// \ingroup ConditionAlgorithms
-template <typename ForwardIterator>
-inline bool is_sorted (ForwardIterator first, ForwardIterator last)
-{
- typedef typename iterator_traits<ForwardIterator>::value_type value_type;
- return (is_sorted (first, last, less<value_type>()));
-}
-
-/// \brief Compares two given containers like strcmp compares strings.
-/// \ingroup ConditionAlgorithms
-template <typename InputIterator1, typename InputIterator2>
-inline bool lexicographical_compare (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2)
-{
- typedef typename iterator_traits<InputIterator1>::value_type value_type;
- return (lexicographical_compare (first1, last1, first2, last2, less<value_type>()));
-}
-
-/// \brief Creates the next lexicographical permutation of [first,last).
-/// Returns false if no further permutations can be created.
-/// \ingroup GeneratorAlgorithms
-template <typename BidirectionalIterator>
-inline bool next_permutation (BidirectionalIterator first, BidirectionalIterator last)
-{
- typedef typename iterator_traits<BidirectionalIterator>::value_type value_type;
- return (next_permutation (first, last, less<value_type>()));
-}
-
-/// \brief Creates the previous lexicographical permutation of [first,last).
-/// Returns false if no further permutations can be created.
-/// \ingroup GeneratorAlgorithms
-template <typename BidirectionalIterator>
-inline bool prev_permutation (BidirectionalIterator first, BidirectionalIterator last)
-{
- typedef typename iterator_traits<BidirectionalIterator>::value_type value_type;
- return (prev_permutation (first, last, less<value_type>()));
-}
-
-/// \brief Returns iterator to the max element in [first,last)
-/// \ingroup SearchingAlgorithms
-template <typename ForwardIterator>
-inline ForwardIterator max_element (ForwardIterator first, ForwardIterator last)
-{
- typedef typename iterator_traits<ForwardIterator>::value_type value_type;
- return (max_element (first, last, less<value_type>()));
-}
-
-/// \brief Returns iterator to the min element in [first,last)
-/// \ingroup SearchingAlgorithms
-template <typename ForwardIterator>
-inline ForwardIterator min_element (ForwardIterator first, ForwardIterator last)
-{
- typedef typename iterator_traits<ForwardIterator>::value_type value_type;
- return (min_element (first, last, less<value_type>()));
-}
-
-/// \brief Makes [first,middle) a part of the sorted array.
-/// Contents of [middle,last) is undefined. This implementation just calls stable_sort.
-/// \ingroup SortingAlgorithms
-template <typename RandomAccessIterator>
-inline void partial_sort (RandomAccessIterator first, RandomAccessIterator middle, RandomAccessIterator last)
-{
- typedef typename iterator_traits<RandomAccessIterator>::value_type value_type;
- partial_sort (first, middle, last, less<value_type>());
-}
-
-/// \brief Puts \p nth element into its sorted position.
-/// In this implementation, the entire array is sorted. I can't think of any
-/// use for it where the time gained would be useful.
-/// \ingroup SortingAlgorithms
-/// \ingroup SearchingAlgorithms
-///
-template <typename RandomAccessIterator>
-inline void nth_element (RandomAccessIterator first, RandomAccessIterator nth, RandomAccessIterator last)
-{
- partial_sort (first, nth, last);
-}
-
-/// \brief Like partial_sort, but outputs to [result_first,result_last)
-/// \ingroup SortingAlgorithms
-template <typename InputIterator, typename RandomAccessIterator>
-inline RandomAccessIterator partial_sort_copy (InputIterator first, InputIterator last, RandomAccessIterator result_first, RandomAccessIterator result_last)
-{
- typedef typename iterator_traits<InputIterator>::value_type value_type;
- return (partial_sort_copy (first, last, result_first, result_last, less<value_type>()));
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ualgobase.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/ualgobase.cpp
deleted file mode 100644
index 9764cd1..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ualgobase.cpp
+++ /dev/null
@@ -1,293 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ualgobase.cc
-//
-// Copy and fill optimizations are here.
-//
-
-#ifndef NDEBUG // Optimized code here. asserts slow it down, and are checked elsewhere.
-#define NDEBUG
-#endif
-
-#include "ualgo.h"
-
-#undef CPU_HAS_MMX
-
-namespace ustl {
-
-// Generic version for implementing fill_nX_fast on non-i386 architectures.
-template <typename T> inline void stosv (T*& p, size_t n, T v)
- { while (n--) *p++ = v; }
-
-#if defined(__i386__) || defined(__x86_64__)
-
-//----------------------------------------------------------------------
-// Copy functions
-//----------------------------------------------------------------------
-
-#if __GNUC__ >= 3
-static inline void movsb_dir_up (void) __attribute__((always_inline));
-static inline void movsb_dir_down (void) __attribute__((always_inline));
-static inline void movsb (const void*& src, size_t nBytes, void*& dest) __attribute__((always_inline));
-static inline void movsd (const void*& src, size_t nWords, void*& dest) __attribute__((always_inline));
-#endif
-
-static inline void movsb_dir_up (void) { asm volatile ("cld"); }
-static inline void movsb_dir_down (void) { asm volatile ("std"); }
-
-static inline void movsb (const void*& src, size_t nBytes, void*& dest)
-{
- asm volatile ("rep;\n\tmovsb"
- : "=&S"(src), "=&D"(dest), "=&c"(nBytes)
- : "0"(src), "1"(dest), "2"(nBytes)
- : "memory");
-}
-
-static inline void movsd (const void*& src, size_t nWords, void*& dest)
-{
- asm volatile ("rep;\n\tmovsl"
- : "=&S"(src), "=&D"(dest), "=&c"(nWords)
- : "0"(src), "1"(dest), "2"(nWords)
- : "memory");
-}
-
-template <> inline void stosv (uint8_t*& p, size_t n, uint8_t v)
-{ asm volatile ("rep;\n\tstosb" : "=&D"(p), "=c"(n) : "0"(p), "1"(n), "a"(v) : "memory"); }
-template <> inline void stosv (uint16_t*& p, size_t n, uint16_t v)
-{ asm volatile ("rep;\n\tstosw" : "=&D"(p), "=c"(n) : "0"(p), "1"(n), "a"(v) : "memory"); }
-template <> inline void stosv (uint32_t*& p, size_t n, uint32_t v)
-{ asm volatile ("rep;\n\tstosl" : "=&D"(p), "=c"(n) : "0"(p), "1"(n), "a"(v) : "memory"); }
-
-#if CPU_HAS_MMX
-#define MMX_ALIGN 16U // Data must be aligned on this grain
-#define MMX_BS 32U // Assembly routines copy data this many bytes at a time.
-
-static inline void simd_block_copy (const void* src, void* dest) __attribute__((always_inline));
-static inline void simd_block_store (uint8_t* dest) __attribute__((always_inline));
-static inline void simd_block_cleanup (void) __attribute__((always_inline));
-
-static inline void simd_block_copy (const void* src, void* dest)
-{
- const char* csrc ((const char*) src);
- char* cdest ((char*) dest);
- #if CPU_HAS_SSE
- asm (
- "movaps\t%2, %%xmm0 \n\t"
- "movaps\t%3, %%xmm1 \n\t"
- "movntps\t%%xmm0, %0 \n\t"
- "movntps\t%%xmm1, %1"
- : "=m"(cdest[0]), "=m"(cdest[16])
- : "m"(csrc[0]), "m"(csrc[16])
- : "xmm0", "xmm1");
- #else
- asm (
- "movq %4, %%mm0 \n\t"
- "movq %5, %%mm1 \n\t"
- "movq %6, %%mm2 \n\t"
- "movq %7, %%mm3 \n\t"
- "movq %%mm0, %0 \n\t"
- "movq %%mm1, %1 \n\t"
- "movq %%mm2, %2 \n\t"
- "movq %%mm3, %3"
- : "=m"(cdest[0]), "=m"(cdest[8]), "=m"(cdest[16]), "=m"(cdest[24])
- : "m"(csrc[0]), "m"(csrc[8]), "m"(csrc[16]), "m"(csrc[24])
- : "mm0", "mm1", "mm2", "mm3", "st", "st(1)", "st(2)", "st(3)");
- #endif
-}
-
-static inline void simd_block_store (uint8_t* dest)
-{
- #if CPU_HAS_SSE
- asm volatile (
- "movntq %%mm0, %0\n\t"
- "movntq %%mm0, %1\n\t"
- "movntq %%mm0, %2\n\t"
- "movntq %%mm0, %3"
- : "=m"(dest[0]), "=m"(dest[8]), "=m"(dest[16]), "=m"(dest[24]));
- #else
- asm volatile (
- "movq %%mm0, %0 \n\t"
- "movq %%mm0, %1 \n\t"
- "movq %%mm0, %2 \n\t"
- "movq %%mm0, %3"
- : "=m"(dest[0]), "=m"(dest[8]), "=m"(dest[16]), "=m"(dest[24]));
- #endif
-}
-
-static inline void simd_block_cleanup (void)
-{
- #if !CPU_HAS_SSE
- simd::reset_mmx();
- #endif
- asm volatile ("sfence");
-}
-
-/// The fastest optimized raw memory copy.
-void copy_n_fast (const void* src, size_t nBytes, void* dest)
-{
- movsb_dir_up();
- size_t nHeadBytes = Align(uintptr_t(src), MMX_ALIGN) - uintptr_t(src);
- nHeadBytes = min (nHeadBytes, nBytes);
- movsb (src, nHeadBytes, dest);
- nBytes -= nHeadBytes;
- if (!(uintptr_t(dest) % MMX_ALIGN)) {
- const size_t nMiddleBlocks = nBytes / MMX_BS;
- for (uoff_t i = 0; i < nMiddleBlocks; ++ i) {
- prefetch (advance (src, 512), 0, 0);
- simd_block_copy (src, dest);
- src = advance (src, MMX_BS);
- dest = advance (dest, MMX_BS);
- }
- simd_block_cleanup();
- nBytes %= MMX_BS;
- }
- movsb (src, nBytes, dest);
-}
-#endif // CPU_HAS_MMX
-
-/// The fastest optimized backwards raw memory copy.
-void copy_backward_fast (const void* first, const void* last, void* result)
-{
- prefetch (first, 0, 0);
- prefetch (result, 1, 0);
- size_t nBytes (distance (first, last));
- movsb_dir_down();
- size_t nHeadBytes = uintptr_t(last) % 4;
- last = advance (last, -1);
- result = advance (result, -1);
- movsb (last, nHeadBytes, result);
- nBytes -= nHeadBytes;
- if (uintptr_t(result) % 4 == 3) {
- const size_t nMiddleBlocks = nBytes / 4;
- last = advance (last, -3);
- result = advance (result, -3);
- movsd (last, nMiddleBlocks, result);
- nBytes %= 4;
- }
- movsb (last, nBytes, result);
- movsb_dir_up();
-}
-#endif // __i386__
-
-//----------------------------------------------------------------------
-// Fill functions
-//----------------------------------------------------------------------
-
-#if CPU_HAS_MMX
-template <typename T> inline void build_block (T) {}
-template <> inline void build_block (uint8_t v)
-{
- asm volatile (
- "movd %0, %%mm0\n\tpunpcklbw %%mm0, %%mm0\n\tpshufw $0, %%mm0, %%mm0"
- : : "g"(uint32_t(v)) : "mm0");
-}
-template <> inline void build_block (uint16_t v)
-{
- asm volatile (
- "movd %0, %%mm0\n\tpshufw $0, %%mm0, %%mm0"
- : : "g"(uint32_t(v)) : "mm0");
-}
-template <> inline void build_block (uint32_t v)
-{
- asm volatile (
- "movd %0, %%mm0\n\tpunpckldq %%mm0, %%mm0"
- : : "g"(uint32_t(v)) : "mm0");
-}
-
-static inline void simd_block_fill_loop (uint8_t*& dest, size_t count)
-{
- prefetch (advance (dest, 512), 1, 0);
- for (uoff_t i = 0; i < count; ++ i, dest += MMX_BS)
- simd_block_store (dest);
- simd_block_cleanup();
- simd::reset_mmx();
-}
-
-template <typename T>
-inline void fill_n_fast (T* dest, size_t count, T v)
-{
- size_t nHead = Align(uintptr_t(dest), MMX_ALIGN) - uintptr_t(dest) / sizeof(T);
- nHead = min (nHead, count);
- stosv (dest, nHead, v);
- count -= nHead;
- build_block (v);
- simd_block_fill_loop ((uint8_t*&) dest, count * sizeof(T) / MMX_BS);
- count %= MMX_BS;
- stosv (dest, count, v);
-}
-
-void fill_n8_fast (uint8_t* dest, size_t count, uint8_t v)
- { fill_n_fast (dest, count, v); }
-void fill_n16_fast (uint16_t* dest, size_t count, uint16_t v)
- { fill_n_fast (dest, count, v); }
-void fill_n32_fast (uint32_t* dest, size_t count, uint32_t v)
- { fill_n_fast (dest, count, v); }
-#else
-void fill_n8_fast (uint8_t* dest, size_t count, uint8_t v) { memset (dest, v, count); }
-void fill_n16_fast (uint16_t* dest, size_t count, uint16_t v) { stosv (dest, count, v); }
-void fill_n32_fast (uint32_t* dest, size_t count, uint32_t v) { stosv (dest, count, v); }
-#endif // CPU_HAS_MMX
-
-/// Exchanges ranges [first, middle) and [middle, last)
-void rotate_fast (void* first, void* middle, void* last)
-{
-#ifdef HAVE_ALLOCA_H
- const size_t half1 (distance (first, middle)), half2 (distance (middle, last));
- const size_t hmin (min (half1, half2));
- if (!hmin) {
- return;
- }
- void* buf = alloca (hmin);
- if (buf) {
- if (half2 < half1) {
- copy_n_fast (middle, half2, buf);
- copy_backward_fast (first, middle, last);
- copy_n_fast (buf, half2, first);
- } else {
- copy_n_fast (first, half1, buf);
- copy_n_fast (middle, half2, first);
- copy_n_fast (buf, half1, advance (first, half2));
- }
- } else
-#else
- if (first == middle || middle == last) {
- return;
- }
-#endif
- {
- char* f = (char*) first;
- char* m = (char*) middle;
- char* l = (char*) last;
- reverse (f, m);
- reverse (m, l);
- while (f != m && m != l)
- iter_swap (f++, --l);
- reverse (f, (f == m ? l : m));
- }
-}
-
-#if __GNUC__ < 4
-size_t popcount (uint32_t v)
-{
- const uint32_t w = v - ((v >> 1) & 0x55555555); // Algorithm from AMD optimization guide
- const uint32_t x = (w & 0x33333333) + ((w >> 2) & 0x33333333);
- return (((x + (x >> 4) & 0x0F0F0F0F) * 0x01010101) >> 24);
-}
-
-#if HAVE_INT64_T
-/// \brief Returns the number of 1s in \p v in binary.
-size_t popcount (uint64_t v)
-{
- v -= (v >> 1) & UINT64_C(0x5555555555555555); // Algorithm from Wikipedia
- v = (v & UINT64_C(0x3333333333333333)) + ((v >> 2) & UINT64_C(0x3333333333333333));
- v = (v + (v >> 4)) & UINT64_C(0x0F0F0F0F0F0F0F0F);
- return ((v * UINT64_C(0x0101010101010101)) >> 56);
-}
-#endif // HAVE_INT64_T
-#endif // !__GNUC__
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ualgobase.h b/media/libdrm/mobile2/src/util/ustl-1.0/ualgobase.h
deleted file mode 100644
index 38c1a72..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ualgobase.h
+++ /dev/null
@@ -1,334 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ualgobase.h
-//
-// Implementation of STL algorithms.
-//
-// The function prototypes are copied
-// exactly from the SGI version of STL documentation along with comments about
-// their use. The code is NOT the same, though the functionality usually is.
-//
-
-#ifndef UALGOBASE_H_683A0BE77546133C4CE0E3622CFAA2EB
-#define UALGOBASE_H_683A0BE77546133C4CE0E3622CFAA2EB
-
-#include "uutility.h"
-#include <string.h>
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-#undef CPU_HAS_MMX
-#endif
-
-namespace ustl {
-
-/// Assigns the contents of a to b and the contents of b to a.
-/// This is used as a primitive operation by many other algorithms.
-/// \ingroup SwapAlgorithms
-///
-template <typename Assignable>
-inline void swap (Assignable& a, Assignable& b)
-{
- Assignable tmp = a;
- a = b;
- b = tmp;
-}
-
-/// Equivalent to swap (*a, *b)
-/// \ingroup SwapAlgorithms
-///
-template <typename Iterator>
-inline void iter_swap (Iterator a, Iterator b)
-{
- swap (*a, *b);
-}
-
-/// Copy copies elements from the range [first, last) to the range
-/// [result, result + (last - first)). That is, it performs the assignments
-/// *result = *first, *(result + 1) = *(first + 1), and so on. [1] Generally,
-/// for every integer n from 0 to last - first, copy performs the assignment
-/// *(result + n) = *(first + n). Assignments are performed in forward order,
-/// i.e. in order of increasing n.
-/// \ingroup MutatingAlgorithms
-///
-template <typename InputIterator, typename OutputIterator>
-inline OutputIterator copy (InputIterator first, InputIterator last, OutputIterator result)
-{
- for (; first != last; ++result, ++first)
- *result = *first;
- return (result);
-}
-
-/// Copy_n copies elements from the range [first, first + n) to the range
-/// [result, result + n). That is, it performs the assignments
-/// *result = *first, *(result + 1) = *(first + 1), and so on. Generally,
-/// for every integer i from 0 up to (but not including) n, copy_n performs
-/// the assignment *(result + i) = *(first + i). Assignments are performed
-/// in forward order, i.e. in order of increasing n.
-/// \ingroup MutatingAlgorithms
-///
-template <typename InputIterator, typename OutputIterator>
-inline OutputIterator copy_n (InputIterator first, size_t count, OutputIterator result)
-{
- for (; count; --count, ++result, ++first)
- *result = *first;
- return (result);
-}
-
-/// \brief Copy copies elements from the range (last, first] to result.
-/// \ingroup MutatingAlgorithms
-/// Copies elements starting at last, decrementing both last and result.
-///
-template <typename InputIterator, typename OutputIterator>
-inline OutputIterator copy_backward (InputIterator first, InputIterator last, OutputIterator result)
-{
- while (first != last)
- *--result = *--last;
- return (result);
-}
-
-/// For_each applies the function object f to each element in the range
-/// [first, last); f's return value, if any, is ignored. Applications are
-/// performed in forward order, i.e. from first to last. For_each returns
-/// the function object after it has been applied to each element.
-/// \ingroup MutatingAlgorithms
-///
-template <typename InputIterator, typename UnaryFunction>
-inline UnaryFunction for_each (InputIterator first, InputIterator last, UnaryFunction f)
-{
- for (; first != last; ++first)
- f (*first);
- return (f);
-}
-
-/// Fill assigns the value value to every element in the range [first, last).
-/// That is, for every iterator i in [first, last),
-/// it performs the assignment *i = value.
-/// \ingroup GeneratorAlgorithms
-///
-template <typename ForwardIterator, typename T>
-inline void fill (ForwardIterator first, ForwardIterator last, const T& value)
-{
- for (; first != last; ++first)
- *first = value;
-}
-
-/// Fill_n assigns the value value to every element in the range
-/// [first, first+count). That is, for every iterator i in [first, first+count),
-/// it performs the assignment *i = value. The return value is first + count.
-/// \ingroup GeneratorAlgorithms
-///
-template <typename OutputIterator, typename T>
-inline OutputIterator fill_n (OutputIterator first, size_t count, const T& value)
-{
- for (; count; --count, ++first)
- *first = value;
- return (first);
-}
-
-#if CPU_HAS_MMX
-extern "C" void copy_n_fast (const void* src, size_t count, void* dest);
-#else
-inline void copy_n_fast (const void* src, size_t count, void* dest)
-{ memcpy (dest, src, count); }
-#endif
-#if __i386__ || __x86_64__
-extern "C" void copy_backward_fast (const void* first, const void* last, void* result);
-#else
-inline void copy_backward_fast (const void* first, const void* last, void* result)
-{
- const size_t nBytes (distance (first, last));
- memmove (advance (result, -nBytes), first, nBytes);
-}
-#endif
-extern "C" void fill_n8_fast (uint8_t* dest, size_t count, uint8_t v);
-extern "C" void fill_n16_fast (uint16_t* dest, size_t count, uint16_t v);
-extern "C" void fill_n32_fast (uint32_t* dest, size_t count, uint32_t v);
-extern "C" void rotate_fast (void* first, void* middle, void* last);
-
-#if __GNUC__ >= 4
-/// \brief Computes the number of 1 bits in a number.
-/// \ingroup ConditionAlgorithms
-inline size_t popcount (uint32_t v) { return (__builtin_popcount (v)); }
-#if HAVE_INT64_T
-inline size_t popcount (uint64_t v) { return (__builtin_popcountll (v)); }
-#endif
-#else
-size_t popcount (uint32_t v);
-#if HAVE_INT64_T
-size_t popcount (uint64_t v);
-#endif // HAVE_INT64_T
-#endif // __GNUC__
-
-//----------------------------------------------------------------------
-// Optimized versions for standard types
-//----------------------------------------------------------------------
-
-#if WANT_UNROLLED_COPY
-
-template <typename T>
-inline T* unrolled_copy (const T* first, size_t count, T* result)
-{
- copy_n_fast (first, count * sizeof(T), result);
- return (advance (result, count));
-}
-
-template <>
-inline uint8_t* copy_backward (const uint8_t* first, const uint8_t* last, uint8_t* result)
-{
- copy_backward_fast (first, last, result);
- return (result);
-}
-
-template <typename T>
-inline T* unrolled_fill (T* result, size_t count, T value)
-{
- for (; count; --count, ++result)
- *result = value;
- return (result);
-}
-template <> inline uint8_t* unrolled_fill (uint8_t* result, size_t count, uint8_t value)
- { fill_n8_fast (result, count, value); return (advance (result, count)); }
-template <> inline uint16_t* unrolled_fill (uint16_t* result, size_t count, uint16_t value)
- { fill_n16_fast (result, count, value); return (advance (result, count)); }
-template <> inline uint32_t* unrolled_fill (uint32_t* result, size_t count, uint32_t value)
- { fill_n32_fast (result, count, value); return (advance (result, count)); }
-template <> inline float* unrolled_fill (float* result, size_t count, float value)
- { fill_n32_fast ((uint32_t*) result, count, noalias(uint32_t(),&value)); return (advance (result, count)); }
-
-#if CPU_HAS_MMX
-#define UNROLLED_COPY_SPECIALIZATION(type) \
-template <> inline type* copy (const type* first, const type* last, type* result) \
-{ return (unrolled_copy (first, distance (first, last), result)); } \
-template <> inline type* copy_n (const type* first, size_t count, type* result) \
-{ return (unrolled_copy (first, count, result)); }
-#define UNROLLED_FILL_SPECIALIZATION(type) \
-template <> inline void fill (type* first, type* last, const type& value) \
-{ unrolled_fill (first, distance (first, last), value); } \
-template <> inline type* fill_n (type* first, size_t count, const type& value) \
-{ return (unrolled_fill (first, count, value)); }
-UNROLLED_COPY_SPECIALIZATION(uint8_t)
-UNROLLED_FILL_SPECIALIZATION(uint8_t)
-UNROLLED_COPY_SPECIALIZATION(uint16_t)
-UNROLLED_FILL_SPECIALIZATION(uint16_t)
-UNROLLED_COPY_SPECIALIZATION(uint32_t)
-UNROLLED_FILL_SPECIALIZATION(uint32_t)
-UNROLLED_COPY_SPECIALIZATION(float)
-UNROLLED_FILL_SPECIALIZATION(float)
-#undef UNROLLED_FILL_SPECIALIZATION
-#undef UNROLLED_COPY_SPECIALIZATION
-#endif // WANT_UNROLLED_COPY
-#endif // CPU_HAS_MMX
-
-// Specializations for void* and char*, aliasing the above optimized versions.
-//
-// All these need duplication with const and non-const arguments, since
-// otherwise the compiler will default to the unoptimized version for
-// pointers not const in the caller's context, such as local variables.
-// These are all inline, but they sure slow down compilation... :(
-//
-#define COPY_ALIAS_FUNC(ctype, type, alias_type) \
-template <> inline type* copy (ctype* first, ctype* last, type* result) \
-{ return ((type*) copy ((const alias_type*) first, (const alias_type*) last, (alias_type*) result)); }
-#if WANT_UNROLLED_COPY
-#if HAVE_THREE_CHAR_TYPES
-COPY_ALIAS_FUNC(const char, char, uint8_t)
-COPY_ALIAS_FUNC(char, char, uint8_t)
-#endif
-COPY_ALIAS_FUNC(const int8_t, int8_t, uint8_t)
-COPY_ALIAS_FUNC(int8_t, int8_t, uint8_t)
-COPY_ALIAS_FUNC(uint8_t, uint8_t, uint8_t)
-COPY_ALIAS_FUNC(const int16_t, int16_t, uint16_t)
-COPY_ALIAS_FUNC(int16_t, int16_t, uint16_t)
-COPY_ALIAS_FUNC(uint16_t, uint16_t, uint16_t)
-#if CPU_HAS_MMX || (SIZE_OF_LONG > 4)
-COPY_ALIAS_FUNC(const int32_t, int32_t, uint32_t)
-COPY_ALIAS_FUNC(int32_t, int32_t, uint32_t)
-COPY_ALIAS_FUNC(uint32_t, uint32_t, uint32_t)
-#endif
-#endif
-COPY_ALIAS_FUNC(const void, void, uint8_t)
-COPY_ALIAS_FUNC(void, void, uint8_t)
-#undef COPY_ALIAS_FUNC
-#define COPY_BACKWARD_ALIAS_FUNC(ctype, type, alias_type) \
-template <> inline type* copy_backward (ctype* first, ctype* last, type* result) \
-{ return ((type*) copy_backward ((const alias_type*) first, (const alias_type*) last, (alias_type*) result)); }
-#if WANT_UNROLLED_COPY
-#if HAVE_THREE_CHAR_TYPES
-COPY_BACKWARD_ALIAS_FUNC(char, char, uint8_t)
-#endif
-COPY_BACKWARD_ALIAS_FUNC(uint8_t, uint8_t, uint8_t)
-COPY_BACKWARD_ALIAS_FUNC(int8_t, int8_t, uint8_t)
-COPY_BACKWARD_ALIAS_FUNC(uint16_t, uint16_t, uint8_t)
-COPY_BACKWARD_ALIAS_FUNC(const uint16_t, uint16_t, uint8_t)
-COPY_BACKWARD_ALIAS_FUNC(int16_t, int16_t, uint8_t)
-COPY_BACKWARD_ALIAS_FUNC(const int16_t, int16_t, uint8_t)
-#endif
-COPY_BACKWARD_ALIAS_FUNC(void, void, uint8_t)
-COPY_BACKWARD_ALIAS_FUNC(const void, void, uint8_t)
-#undef COPY_BACKWARD_ALIAS_FUNC
-#define FILL_ALIAS_FUNC(type, alias_type, v_type) \
-template <> inline void fill (type* first, type* last, const v_type& value) \
-{ fill ((alias_type*) first, (alias_type*) last, (const alias_type&) value); }
-FILL_ALIAS_FUNC(void, uint8_t, char)
-FILL_ALIAS_FUNC(void, uint8_t, uint8_t)
-#if WANT_UNROLLED_COPY
-#if HAVE_THREE_CHAR_TYPES
-FILL_ALIAS_FUNC(char, uint8_t, char)
-FILL_ALIAS_FUNC(char, uint8_t, uint8_t)
-#endif
-FILL_ALIAS_FUNC(int8_t, uint8_t, int8_t)
-FILL_ALIAS_FUNC(int16_t, uint16_t, int16_t)
-#if CPU_HAS_MMX || (SIZE_OF_LONG > 4)
-FILL_ALIAS_FUNC(int32_t, uint32_t, int32_t)
-#endif
-#endif
-#undef FILL_ALIAS_FUNC
-#define COPY_N_ALIAS_FUNC(ctype, type, alias_type) \
-template <> inline type* copy_n (ctype* first, size_t count, type* result) \
-{ return ((type*) copy_n ((const alias_type*) first, count, (alias_type*) result)); }
-COPY_N_ALIAS_FUNC(const void, void, uint8_t)
-COPY_N_ALIAS_FUNC(void, void, uint8_t)
-#if WANT_UNROLLED_COPY
-#if HAVE_THREE_CHAR_TYPES
-COPY_N_ALIAS_FUNC(const char, char, uint8_t)
-COPY_N_ALIAS_FUNC(char, char, uint8_t)
-#endif
-COPY_N_ALIAS_FUNC(int8_t, int8_t, uint8_t)
-COPY_N_ALIAS_FUNC(uint8_t, uint8_t, uint8_t)
-COPY_N_ALIAS_FUNC(const int8_t, int8_t, uint8_t)
-COPY_N_ALIAS_FUNC(int16_t, int16_t, uint16_t)
-COPY_N_ALIAS_FUNC(uint16_t, uint16_t, uint16_t)
-COPY_N_ALIAS_FUNC(const int16_t, int16_t, uint16_t)
-#if CPU_HAS_MMX || (SIZE_OF_LONG > 4)
-COPY_N_ALIAS_FUNC(int32_t, int32_t, uint32_t)
-COPY_N_ALIAS_FUNC(uint32_t, uint32_t, uint32_t)
-COPY_N_ALIAS_FUNC(const int32_t, int32_t, uint32_t)
-#endif
-#endif
-#undef COPY_N_ALIAS_FUNC
-#define FILL_N_ALIAS_FUNC(type, alias_type, v_type) \
-template <> inline type* fill_n (type* first, size_t n, const v_type& value) \
-{ return ((type*) fill_n ((alias_type*) first, n, (const alias_type&) value)); }
-FILL_N_ALIAS_FUNC(void, uint8_t, char)
-FILL_N_ALIAS_FUNC(void, uint8_t, uint8_t)
-#if WANT_UNROLLED_COPY
-#if HAVE_THREE_CHAR_TYPES
-FILL_N_ALIAS_FUNC(char, uint8_t, char)
-FILL_N_ALIAS_FUNC(char, uint8_t, uint8_t)
-#endif
-FILL_N_ALIAS_FUNC(int8_t, uint8_t, int8_t)
-FILL_N_ALIAS_FUNC(int16_t, uint16_t, int16_t)
-#if CPU_HAS_MMX || (SIZE_OF_LONG > 4)
-FILL_N_ALIAS_FUNC(int32_t, uint32_t, int32_t)
-#endif
-#endif
-#undef FILL_N_ALIAS_FUNC
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uassert.h b/media/libdrm/mobile2/src/util/ustl-1.0/uassert.h
deleted file mode 100644
index a9fde46..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uassert.h
+++ /dev/null
@@ -1,21 +0,0 @@
-// uassert.h
-
-#ifndef UASSERT_H
-#define UASSERT_H
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-
-#undef assert
-#define assert(x) _uassert((x), #x, __FILE__, __LINE__)
-
-static void _uassert(int x, const char *xstr, const char *file, int line) {
- if (!x) {
- printf("assert %s failed at %s:%d\n", xstr, file, line);
- }
-}
-#else
-#include <assert.h>
-#endif
-
-#endif
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ubitset.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/ubitset.cpp
deleted file mode 100644
index 21b5a7a..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ubitset.cpp
+++ /dev/null
@@ -1,38 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ubitset.cc
-//
-
-#include "ubitset.h"
-
-namespace ustl {
-
-/// Copies bits from \p v of size \p n into \p buf as MSB "1011001..." LSB
-/// If \p buf is too small, MSB bits will be truncated.
-void convert_to_bitstring (const bitset_value_type* v, size_t n, string& buf)
-{
- string::iterator stri = buf.end();
- for (size_t i = 0; i < n && stri > buf.begin(); ++ i)
- for (bitset_value_type b = 1; b && stri > buf.begin(); b <<= 1)
- *--stri = (v[i] & b) ? '1' : '0';
-}
-
-/// Copies bits from \p buf as MSB "1011001..." LSB into \p v of size \p n.
-void convert_from_bitstring (const string& buf, bitset_value_type* v, size_t n)
-{
- string::const_iterator stri = buf.end();
- for (size_t i = 0; i < n; ++ i) {
- for (bitset_value_type b = 1; b; b <<= 1) {
- if (stri == buf.begin() || *--stri == '0')
- v[i] &= ~b;
- else
- v[i] |= b;
- }
- }
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ubitset.h b/media/libdrm/mobile2/src/util/ustl-1.0/ubitset.h
deleted file mode 100644
index 4f53a95..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ubitset.h
+++ /dev/null
@@ -1,131 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ubitset.h
-//
-#ifndef UBITSET_H_7B6450EC1400CBA45DCE0127739F82EE
-#define UBITSET_H_7B6450EC1400CBA45DCE0127739F82EE
-
-#include "uassert.h"
-#include "ustring.h"
-#include "ufunction.h"
-
-namespace ustl {
-
-typedef uint32_t bitset_value_type;
-
-void convert_to_bitstring (const bitset_value_type* v, size_t n, string& buf);
-void convert_from_bitstring (const string& buf, bitset_value_type* v, size_t n);
-
-/// \class bitset ubitset.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief bitset is a fixed-size block of memory with addressable bits.
-///
-/// Normally used for state flags; allows setting and unsetting of individual
-/// bits as well as bitwise operations on the entire set. The interface is
-/// most like that of unsigned integers, and is intended to be used as such.
-/// If you were using begin() and end() functions in STL's bitset, you would
-/// not be able to do the same thing here, because those functions return
-/// host type iterators, not bits.
-///
-template <size_t Size>
-class bitset {
-public:
- typedef bitset_value_type value_type;
- typedef value_type* pointer;
- typedef const value_type* const_pointer;
- typedef pointer iterator;
- typedef const_pointer const_iterator;
- typedef size_t difference_type;
- typedef size_t size_type;
-private:
- static const size_t s_WordBits = BitsInType (value_type);
- static const size_t s_nWords = Size / s_WordBits + ((Size % s_WordBits) != 0);
- static const size_t s_nBits = s_nWords * s_WordBits;
-private:
- inline value_type& BitRef (uoff_t n) { assert (n < Size); return (m_Bits [n / s_WordBits]); }
- inline const value_type BitRef (uoff_t n) const { assert (n < Size); return (m_Bits [n / s_WordBits]); }
- inline const value_type Mask (uoff_t n) const { assert (n < Size); return (1 << (n % s_WordBits)); }
-public:
- inline bitset (value_type v = 0) { fill_n (m_Bits, s_nWords, 0); m_Bits[0] = v; }
- inline bitset (const string& buf) { convert_from_bitstring (buf, m_Bits, s_nWords); }
- inline void flip (uoff_t n) { BitRef(n) ^= Mask(n); }
- inline void reset (void) { fill_n (m_Bits, s_nWords, 0); }
- inline void clear (void) { fill_n (m_Bits, s_nWords, 0); }
- inline void set (void) { fill_n (m_Bits, s_nWords, -1); }
- inline bitset operator~ (void) const { bitset rv (*this); rv.flip(); return (rv); }
- inline size_type size (void) const { return (Size); }
- inline size_type capacity (void) const { return (s_nBits); }
- inline const bool test (uoff_t n) const { return (BitRef(n) & Mask(n)); }
- inline const bool operator[] (uoff_t n) const { return (test(n)); }
- inline const_iterator begin (void) const { return (m_Bits); }
- inline iterator begin (void) { return (m_Bits); }
- inline const_iterator end (void) const { return (m_Bits + s_nWords); }
- inline iterator end (void) { return (m_Bits + s_nWords); }
- /// Returns the value_type with the equivalent bits. If size() > 1, you'll get only the first BitsInType(value_type) bits.
- inline const value_type to_value (void) const { return (m_Bits[0]); }
- /// Flips all the bits in the set.
- inline void flip (void) { transform (begin(), end(), begin(), bitwise_not<value_type>()); }
- /// Sets or clears bit \p n.
- inline void set (uoff_t n, bool val = true)
- {
- value_type& br (BitRef (n));
- const value_type mask (Mask (n));
- const value_type bOn (br | mask), bOff (br & ~mask);
- br = val ? bOn : bOff;
- }
- // Sets the value of the bitrange \p first through \p last to the equivalent number of bits from \p v.
- inline void set (uoff_t first, uoff_t DebugArg(last), value_type v)
- {
-#if !PLATFORM_ANDROID
- assert (size_t (distance (first, last)) <= s_WordBits && "Bit ranges must be 32 bits or smaller");
- assert (first / s_WordBits == last / s_WordBits && "Bit ranges can not cross dword (4 byte) boundary");
- assert ((v & BitMask(value_type,distance(first,last))) == v && "The value is too large to fit in the given bit range");
-#endif
- BitRef(first) |= v << (first % s_WordBits);
- }
- /// Clears the bit \p n.
- inline void reset (uoff_t n) { set (n, false); }
- /// Returns a string with bits MSB "001101001..." LSB.
- inline string to_string (void) const
- {
- string rv (Size, '0');
- convert_to_bitstring (m_Bits, s_nWords, rv);
- return (rv);
- }
- inline value_type at (uoff_t n) const { return (test(n)); }
- /// Returns the value in bits \p first through \p last.
- inline value_type at (uoff_t first, uoff_t last) const
- {
- assert (size_t (distance (first, last)) <= s_WordBits && "Bit ranges must be 32 bits or smaller");
- assert (first / s_WordBits == last / s_WordBits && "Bit ranges can not cross dword (4 byte) boundary");
- return ((BitRef(first) >> (first % s_WordBits)) & BitMask(value_type,distance(first, last)));
- }
- inline bool any (void) const { value_type sum = 0; foreach (const_iterator, i, *this) sum |= *i; return (sum); }
- inline bool none (void) const { return (!any()); }
- inline size_t count (void) const { size_t sum = 0; foreach (const_iterator, i, *this) sum += popcount(*i); return (sum); }
- inline bool operator== (const bitset<Size>& v) const
- { return (s_nWords == 1 ? (m_Bits[0] == v.m_Bits[0]) : equal (begin(), end(), v.begin())); }
- inline const bitset operator& (const bitset<Size>& v)
- { bitset<Size> result; transform (begin(), end(), v.begin(), result.begin(), bitwise_and<value_type>()); return (result); }
- inline const bitset operator| (const bitset<Size>& v)
- { bitset<Size> result; transform (begin(), end(), v.begin(), result.begin(), bitwise_or<value_type>()); return (result); }
- inline const bitset operator^ (const bitset<Size>& v)
- { bitset<Size> result; transform (begin(), end(), v.begin(), result.begin(), bitwise_xor<value_type>()); return (result); }
- inline const bitset& operator&= (const bitset<Size>& v)
- { transform (begin(), end(), v.begin(), begin(), bitwise_and<value_type>()); return (*this); }
- inline const bitset& operator|= (const bitset<Size>& v)
- { transform (begin(), end(), v.begin(), begin(), bitwise_or<value_type>()); return (*this); }
- inline const bitset& operator^= (const bitset<Size>& v)
- { transform (begin(), end(), v.begin(), begin(), bitwise_xor<value_type>()); return (*this); }
-private:
- value_type m_Bits [s_nWords];
-};
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uctralgo.h b/media/libdrm/mobile2/src/util/ustl-1.0/uctralgo.h
deleted file mode 100644
index 57f637d..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uctralgo.h
+++ /dev/null
@@ -1,482 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// \file uctralgo.h
-//
-// \brief Implementation of STL algorithms with container shortcuts.
-//
-// The function prototypes are copied
-// exactly from the SGI version of STL documentation along with comments about
-// their use. The code is NOT the same, though the functionality usually is.
-//
-
-#ifndef UCTRALGO_H_0D1AEDFA74B09791489FE25B1EC644B0
-#define UCTRALGO_H_0D1AEDFA74B09791489FE25B1EC644B0
-
-#include "uassert.h"
-
-namespace ustl {
-
-/// Copy copies elements from the range [first, last) to the range
-/// [result, result + (last - first)). That is, it performs the assignments
-/// *result = *first, *(result + 1) = *(first + 1), and so on. [1] Generally,
-/// for every integer n from 0 to last - first, copy performs the assignment
-/// *(result + n) = *(first + n). Assignments are performed in forward order,
-/// i.e. in order of increasing n.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename OutputIterator>
-inline OutputIterator copy (const Container& ctr, OutputIterator result)
-{
- return (copy (ctr.begin(), ctr.end(), result));
-}
-
-/// Copy_if copies elements from the range [first, last) to the range
-/// [result, result + (last - first)) if pred(*i) returns true.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename OutputIterator, typename Predicate>
-inline OutputIterator copy_if (Container& ctr, OutputIterator result, Predicate pred)
-{
- return (copy_if (ctr.begin(), ctr.end(), result, pred));
-}
-
-/// For_each applies the function object f to each element in the range
-/// [first, last); f's return value, if any, is ignored. Applications are
-/// performed in forward order, i.e. from first to last. For_each returns
-/// the function object after it has been applied to each element.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename UnaryFunction>
-inline UnaryFunction for_each (Container& ctr, UnaryFunction f)
-{
- return (for_each (ctr.begin(), ctr.end(), f));
-}
-
-/// For_each applies the function object f to each element in the range
-/// [first, last); f's return value, if any, is ignored. Applications are
-/// performed in forward order, i.e. from first to last. For_each returns
-/// the function object after it has been applied to each element.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename UnaryFunction>
-inline UnaryFunction for_each (const Container& ctr, UnaryFunction f)
-{
- return (for_each (ctr.begin(), ctr.end(), f));
-}
-
-/// Returns the first iterator i in the range [first, last) such that
-/// *i == value. Returns last if no such iterator exists.
-/// \ingroup SearchingAlgorithms
-///
-template <typename Container, typename EqualityComparable>
-inline typename Container::const_iterator find (const Container& ctr, const EqualityComparable& value)
-{
- return (find (ctr.begin(), ctr.end(), value));
-}
-template <typename Container, typename EqualityComparable>
-inline typename Container::iterator find (Container& ctr, const EqualityComparable& value)
-{
- return (find (ctr.begin(), ctr.end(), value));
-}
-
-/// Returns the first iterator i in the range [first, last) such that
-/// pred(*i) is true. Returns last if no such iterator exists.
-/// \ingroup SearchingAlgorithms
-///
-template <typename Container, typename Predicate>
-inline typename Container::const_iterator find_if (const Container& ctr, Predicate pred)
-{
- return (find_if (ctr.begin(), ctr.end(), pred));
-}
-template <typename Container, typename Predicate>
-inline typename Container::iterator find_if (Container& ctr, Predicate pred)
-{
- return (find_if (ctr.begin(), ctr.end(), pred));
-}
-
-/// Count finds the number of elements in [first, last) that are equal
-/// to value. More precisely, the first version of count returns the
-/// number of iterators i in [first, last) such that *i == value.
-/// \ingroup ConditionAlgorithms
-///
-template <typename Container, typename EqualityComparable>
-inline size_t count (const Container& ctr, const EqualityComparable& value)
-{
- return (count (ctr.begin(), ctr.end(), value));
-}
-
-/// Count_if finds the number of elements in [first, last) that satisfy the
-/// predicate pred. More precisely, the first version of count_if returns the
-/// number of iterators i in [first, last) such that pred(*i) is true.
-/// \ingroup ConditionAlgorithms
-///
-template <typename Container, typename Predicate>
-inline size_t count_if (const Container& ctr, Predicate pred)
-{
- return (count_if (ctr.begin(), ctr.end(), pred));
-}
-
-/// The first version of transform performs the operation op(*i) for each
-/// iterator i in the range [first, last), and assigns the result of that
-/// operation to *o, where o is the corresponding output iterator. That is,
-/// for each n such that 0 <= n < last - first, it performs the assignment
-/// *(result + n) = op(*(first + n)).
-/// The return value is result + (last - first).
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename UnaryFunction>
-inline void transform (Container& ctr, UnaryFunction op)
-{
- transform (ctr.begin(), ctr.end(), ctr.begin(), op);
-}
-
-/// The first version of transform performs the operation op(*i) for each
-/// iterator i in the range [first, last), and assigns the result of that
-/// operation to *o, where o is the corresponding output iterator. That is,
-/// for each n such that 0 <= n < last - first, it performs the assignment
-/// *(result + n) = op(*(first + n)).
-/// The return value is result + (last - first).
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename OutputIterator, typename UnaryFunction>
-inline OutputIterator transform (Container& ctr, OutputIterator result, UnaryFunction op)
-{
- return (transform (ctr.begin(), ctr.end(), result, op));
-}
-
-/// The second version of transform is very similar, except that it uses a
-/// Binary Function instead of a Unary Function: it performs the operation
-/// op(*i1, *i2) for each iterator i1 in the range [first1, last1) and assigns
-/// the result to *o, where i2 is the corresponding iterator in the second
-/// input range and where o is the corresponding output iterator. That is,
-/// for each n such that 0 <= n < last1 - first1, it performs the assignment
-/// *(result + n) = op(*(first1 + n), *(first2 + n).
-/// The return value is result + (last1 - first1).
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename InputIterator, typename OutputIterator, typename BinaryFunction>
-inline OutputIterator transform (Container& ctr, InputIterator first, OutputIterator result, BinaryFunction op)
-{
- return (transform (ctr.begin(), ctr.end(), first, result, op));
-}
-
-/// Replace replaces every element in the range [first, last) equal to
-/// old_value with new_value. That is: for every iterator i,
-/// if *i == old_value then it performs the assignment *i = new_value.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename T>
-inline void replace (Container& ctr, const T& old_value, const T& new_value)
-{
- replace (ctr.begin(), ctr.end(), old_value, new_value);
-}
-
-/// Replace_if replaces every element in the range [first, last) for which
-/// pred returns true with new_value. That is: for every iterator i, if
-/// pred(*i) is true then it performs the assignment *i = new_value.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename Predicate, typename T>
-inline void replace_if (Container& ctr, Predicate pred, const T& new_value)
-{
- replace_if (ctr.begin(), ctr.end(), pred, new_value);
-}
-
-/// Replace_copy copies elements from the range [first, last) to the range
-/// [result, result + (last-first)), except that any element equal to old_value
-/// is not copied; new_value is copied instead. More precisely, for every
-/// integer n such that 0 <= n < last-first, replace_copy performs the
-/// assignment *(result+n) = new_value if *(first+n) == old_value, and
-/// *(result+n) = *(first+n) otherwise.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename OutputIterator, typename T>
-inline OutputIterator replace_copy (const Container& ctr, OutputIterator result, const T& old_value, const T& new_value)
-{
- return (replace_copy (ctr.begin(), ctr.end(), result, old_value, new_value));
-}
-
-/// Replace_copy_if copies elements from the range [first, last) to the range
-/// [result, result + (last-first)), except that any element for which pred is
-/// true is not copied; new_value is copied instead. More precisely, for every
-/// integer n such that 0 <= n < last-first, replace_copy_if performs the
-/// assignment *(result+n) = new_value if pred(*(first+n)),
-/// and *(result+n) = *(first+n) otherwise.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename OutputIterator, typename Predicate, typename T>
-inline OutputIterator replace_copy_if (const Container& ctr, OutputIterator result, Predicate pred, const T& new_value)
-{
- return (replace_copy_if (ctr.begin(), ctr.end(), result, pred, new_value));
-}
-
-/// Fill assigns the value value to every element in the range [first, last).
-/// That is, for every iterator i in [first, last),
-/// it performs the assignment *i = value.
-/// \ingroup GeneratorAlgorithms
-///
-template <typename Container, typename T>
-inline void fill (Container& ctr, const T& value)
-{
- fill (ctr.begin(), ctr.end(), value);
-}
-
-/// Generate assigns the result of invoking gen, a function object that
-/// takes no arguments, to each element in the range [first, last).
-/// \ingroup GeneratorAlgorithms
-///
-template <typename Container, typename Generator>
-inline void generate (Container& ctr, Generator gen)
-{
- generate (ctr.begin(), ctr.end(), gen);
-}
-
-/// Randomly permute the elements of the container.
-/// \ingroup GeneratorAlgorithms
-///
-template <typename Container>
-inline void random_shuffle (Container& ctr)
-{
- random_shuffle (ctr.begin(), ctr.end());
-}
-
-/// Remove_copy copies elements that are not equal to value from the range
-/// [first, last) to a range beginning at result. The return value is the
-/// end of the resulting range. This operation is stable, meaning that the
-/// relative order of the elements that are copied is the same as in the
-/// range [first, last).
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename OutputIterator, typename T>
-inline OutputIterator remove_copy (const Container& ctr, OutputIterator result, const T& value)
-{
- return (remove_copy (ctr.begin(), ctr.end(), result, value));
-}
-
-/// Remove_copy_if copies elements from the range [first, last) to a range
-/// beginning at result, except that elements for which pred is true are not
-/// copied. The return value is the end of the resulting range. This operation
-/// is stable, meaning that the relative order of the elements that are copied
-/// is the same as in the range [first, last).
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename OutputIterator, typename Predicate>
-inline OutputIterator remove_copy_if (const Container& ctr, OutputIterator result, Predicate pred)
-{
- return (remove_copy_if (ctr.begin(), ctr.end(), result, pred));
-}
-
-/// Remove removes from the range [first, last) all elements that are equal to
-/// value. That is, remove returns an iterator new_last such that the range
-/// [first, new_last) contains no elements equal to value. Remove is stable,
-/// meaning that the relative order of elements that are not equal to value is
-/// unchanged.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename T>
-inline void remove (Container& ctr, const T& value)
-{
- ctr.erase (remove_copy (ctr.begin(), ctr.end(), ctr.begin(), value), ctr.end());
-}
-
-/// Remove removes from the range [first, last) all elements that have an iterator
-/// in range [rfirst, rlast). The range is assumed to be sorted. That is, remove
-/// returns an iterator new_last such that the range [first, new_last) contains
-/// no elements whose iterators are in [rfirst, rlast). Remove is stable,
-/// meaning that the relative order of elements that are not equal to value is
-/// unchanged. This version of the algorithm is a uSTL extension.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename ForwardIterator>
-inline void remove (Container& ctr, ForwardIterator rfirst, ForwardIterator rlast)
-{
- ctr.erase (remove_copy (ctr.begin(), ctr.end(), ctr.begin(), rfirst, rlast), ctr.end());
-}
-
-/// Remove_if removes from the range [first, last) every element x such that
-/// pred(x) is true. That is, remove_if returns an iterator new_last such that
-/// the range [first, new_last) contains no elements for which pred is true.
-/// The iterators in the range [new_last, last) are all still dereferenceable,
-/// but the elements that they point to are unspecified. Remove_if is stable,
-/// meaning that the relative order of elements that are not removed is
-/// unchanged.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename Predicate>
-inline void remove_if (Container& ctr, Predicate pred)
-{
- ctr.erase (remove_copy_if (ctr.begin(), ctr.end(), ctr.begin(), pred), ctr.end());
-}
-
-/// Unique_copy copies elements from the range [first, last) to a range
-/// beginning with result, except that in a consecutive group of duplicate
-/// elements only the first one is copied. The return value is the end of
-/// the range to which the elements are copied. This behavior is similar
-/// to the Unix filter uniq.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename OutputIterator>
-inline OutputIterator unique_copy (const Container& ctr, OutputIterator result)
-{
- return (unique_copy (ctr.begin(), ctr.end(), result));
-}
-
-/// Every time a consecutive group of duplicate elements appears in the range
-/// [first, last), the algorithm unique removes all but the first element.
-/// That is, unique returns an iterator new_last such that the range [first,
-/// new_last) contains no two consecutive elements that are duplicates.
-/// The iterators in the range [new_last, last) are all still dereferenceable,
-/// but the elements that they point to are unspecified. Unique is stable,
-/// meaning that the relative order of elements that are not removed is
-/// unchanged.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container>
-inline void unique (Container& ctr)
-{
- ctr.erase (unique_copy (ctr.begin(), ctr.end(), ctr.begin()), ctr.end());
-}
-
-/// Every time a consecutive group of duplicate elements appears in the range
-/// [first, last), the algorithm unique removes all but the first element.
-/// That is, unique returns an iterator new_last such that the range [first,
-/// new_last) contains no two consecutive elements that are duplicates.
-/// The iterators in the range [new_last, last) are all still dereferenceable,
-/// but the elements that they point to are unspecified. Unique is stable,
-/// meaning that the relative order of elements that are not removed is
-/// unchanged.
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container, typename BinaryPredicate>
-inline void unique (Container& ctr, BinaryPredicate binary_pred)
-{
- ctr.erase (unique_copy (ctr.begin(), ctr.end(), ctr.begin(), binary_pred), ctr.end());
-}
-
-/// Reverse reverses a range.
-/// That is: for every i such that 0 <= i <= (last - first) / 2),
-/// it exchanges *(first + i) and *(last - (i + 1)).
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container>
-inline void reverse (Container& ctr)
-{
- reverse (ctr.begin(), ctr.end());
-}
-
-/// Exchanges ranges [first, middle) and [middle, last)
-/// \ingroup MutatingAlgorithms
-///
-template <typename Container>
-inline void rotate (Container& ctr, off_t offset)
-{
- assert (size_t(offset > 0 ? offset : -offset) < ctr.size());
- if (offset > 0)
- rotate (ctr.begin(), ctr.end() - offset, ctr.end());
- else
- rotate (ctr.begin(), ctr.begin() - offset, ctr.end());
-}
-
-/// Returns the furthermost iterator i in [first, last) such that,
-/// for every iterator j in [first, i), *j < value
-/// Assumes the range is sorted.
-/// \ingroup SearchingAlgorithms
-///
-template <typename Container, typename LessThanComparable>
-inline typename Container::const_iterator lower_bound (const Container& ctr, const LessThanComparable& value)
-{
- return (lower_bound (ctr.begin(), ctr.end(), value));
-}
-template <typename Container, typename LessThanComparable>
-inline typename Container::iterator lower_bound (Container& ctr, const LessThanComparable& value)
-{
- return (lower_bound (ctr.begin(), ctr.end(), value));
-}
-
-/// Returns the furthermost iterator i in [first,last) such that for
-/// every iterator j in [first,i), value < *j is false.
-/// \ingroup SearchingAlgorithms
-///
-template <typename Container, typename LessThanComparable>
-inline typename Container::const_iterator upper_bound (const Container& ctr, const LessThanComparable& value)
-{
- return (upper_bound (ctr.begin(), ctr.end(), value));
-}
-template <typename Container, typename LessThanComparable>
-inline typename Container::iterator upper_bound (Container& ctr, const LessThanComparable& value)
-{
- return (upper_bound (ctr.begin(), ctr.end(), value));
-}
-
-/// Performs a binary search for \p value.
-/// Assumes the range is sorted.
-/// \ingroup SearchingAlgorithms
-///
-template <typename Container>
-inline typename Container::const_iterator binary_search (const Container& ctr, const typename Container::value_type& value)
-{
- return (binary_search (ctr.begin(), ctr.end(), value));
-}
-template <typename Container>
-inline typename Container::iterator binary_search (Container& ctr, const typename Container::value_type& value)
-{
- return (binary_search (ctr.begin(), ctr.end(), value));
-}
-
-/// Returns pair<lower_bound,upper_bound>
-/// \ingroup SearchingAlgorithms
-///
-template <typename Container, typename LessThanComparable>
-inline pair<typename Container::const_iterator,typename Container::const_iterator> equal_range (const Container& ctr, const LessThanComparable& value)
-{
- return (equal_range (ctr.begin(), ctr.end(), value));
-}
-template <typename Container, typename LessThanComparable>
-inline pair<typename Container::iterator,typename Container::iterator> equal_range (Container& ctr, const LessThanComparable& value)
-{
- return (equal_range (ctr.begin(), ctr.end(), value));
-}
-
-/// Sorts the container
-/// \ingroup SortingAlgorithms
-///
-template <typename Container>
-inline void sort (Container& ctr)
-{
- sort (ctr.begin(), ctr.end());
-}
-
-/// Sorts the container
-/// \ingroup SortingAlgorithms
-///
-template <typename Container, typename Compare>
-inline void sort (Container& ctr, Compare comp)
-{
- sort (ctr.begin(), ctr.end(), comp);
-}
-
-/// Sorts the container
-/// \ingroup SortingAlgorithms
-///
-template <typename Container>
-inline void stable_sort (Container& ctr)
-{
- stable_sort (ctr.begin(), ctr.end());
-}
-
-/// Sorts the container
-/// \ingroup SortingAlgorithms
-///
-template <typename Container, typename Compare>
-inline void stable_sort (Container& ctr, Compare comp)
-{
- stable_sort (ctr.begin(), ctr.end(), comp);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uctrstrm.h b/media/libdrm/mobile2/src/util/ustl-1.0/uctrstrm.h
deleted file mode 100644
index 39ddcdd..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uctrstrm.h
+++ /dev/null
@@ -1,177 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-/// \file uctrstrm.h
-///
-/// \brief Serialization templates for standard containers.
-/// Because containers are templates, a single operator>> is impossible.
-/// Making virtual read/write is also impossible because not all containers
-/// contain serializable elements. Therefore, use the macros in this file.
-///
-
-#ifndef UCTRSTRM_H_75B2C3EA4980DDDC6B6DFFF767A3B7AC
-#define UCTRSTRM_H_75B2C3EA4980DDDC6B6DFFF767A3B7AC
-
-#include "mistream.h"
-#include "sostream.h"
-#include "uiosfunc.h"
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-// Macros for easily declaring a container streamable.
-//----------------------------------------------------------------------
-
-/// \brief Declares container template \p type streamable.
-///
-/// Use TEMPLATE_TYPE and TEMPLATE_DECL macros to pass in templated
-/// type with commas and the template declaration.
-///
-#define STD_TEMPLATE_CTR_STREAMABLE(type, template_decl) \
- template_decl \
- inline istream& operator>> (istream& is, type& v) \
- { return (container_read (is, v)); } \
- template_decl \
- inline ostream& operator<< (ostream& os, const type& v) \
- { return (container_write (os, v)); } \
- template_decl \
- inline ostringstream& operator<< (ostringstream& os, const type& v) \
- { return (container_text_write (os, v)); } \
- template_decl \
- inline size_t stream_size_of (const type& v) \
- { return (container_stream_size (v)); }
-
-/// \brief Declares non-resizable container template \p type streamable.
-#define STD_TEMPLATE_NR_CTR_STREAMABLE(type, template_decl) \
- template_decl \
- inline istream& operator>> (istream& is, type& v) \
- { return (nr_container_read (is, v)); } \
- template_decl \
- inline ostream& operator<< (ostream& os, const type& v) \
- { return (nr_container_write (os, v)); } \
- template_decl \
- inline ostringstream& operator<< (ostringstream& os, const type& v) \
- { return (container_text_write (os, v)); } \
- template_decl \
- inline size_t stream_size_of (const type& v) \
- { return (nr_container_stream_size (v)); }
-
-//----------------------------------------------------------------------
-// Fixed size container serialization.
-//----------------------------------------------------------------------
-
-/// Reads fixed size container \p v from stream \p is.
-template <typename Container>
-inline istream& nr_container_read (istream& is, Container& v)
-{
- foreach (typename Container::iterator, i, v)
- is >> *i;
- return (is);
-}
-
-/// Writes fixed size container \p v into stream \p os.
-template <typename Container>
-inline ostream& nr_container_write (ostream& os, const Container& v)
-{
- foreach (typename Container::const_iterator, i, v)
- os << *i;
- return (os);
-}
-
-/// Computes the stream size of a fixed size standard container.
-template <typename Container>
-size_t nr_container_stream_size (const Container& v)
-{
- typedef typename Container::const_iterator vciter_t;
- typedef typename iterator_traits<vciter_t>::value_type value_type;
- size_t s = 0;
- if (numeric_limits<value_type>::is_integral)
- s += v.size() * stream_size_of(value_type());
- else
- foreach (vciter_t, i, v)
- s += stream_size_of(*i);
- return (s);
-}
-
-//----------------------------------------------------------------------
-// Resizable container serialization.
-//----------------------------------------------------------------------
-
-/// Reads container \p v from stream \p is.
-template <typename Container>
-istream& container_read (istream& is, Container& v)
-{
- typedef typename Container::value_type value_type;
- typedef typename Container::iterator iterator;
- typedef typename Container::written_size_type written_size_type;
- written_size_type n;
- is >> n;
- const size_t expectedSize = n * stream_size_of(value_type());
-#if !PLATFORM_ANDROID
- is.verify_remaining ("read", typeid(v).name(), expectedSize);
-#endif
- if (alignof(value_type()) > alignof(n))
- is >> ios::talign<value_type>();
- v.resize (n);
- nr_container_read (is, v);
- is >> ios::talign<written_size_type>();
- return (is);
-}
-
-/// Writes the vector to stream \p os.
-template <typename Container>
-ostream& container_write (ostream& os, const Container& v)
-{
- typedef typename Container::value_type value_type;
- typedef typename Container::written_size_type written_size_type;
- const written_size_type sz (v.size());
- os << sz;
- if (alignof(value_type()) > alignof(sz))
- os << ios::talign<value_type>();
- nr_container_write (os, v);
- os << ios::talign<written_size_type>();
- return (os);
-}
-
-/// Computes the stream size of a standard container.
-template <typename Container>
-size_t container_stream_size (const Container& v)
-{
- typedef typename Container::value_type value_type;
- typedef typename Container::written_size_type written_size_type;
- const written_size_type sz (v.size());
- size_t sizeSize = stream_size_of (sz);
- if (alignof(value_type()) > alignof(sz))
- sizeSize = Align (sizeSize, alignof(value_type()));
- return (Align (sizeSize + nr_container_stream_size (v), alignof(sz)));
-}
-
-/// \brief Writes element \p v into stream \p os as text.
-/// Specialize to custom print elements.
-template <typename T>
-inline ostringstream& container_element_text_write (ostringstream& os, const T& v)
-{ return (os << v); }
-
-/// Writes container \p v into stream \p os as text.
-template <typename Container>
-ostringstream& container_text_write (ostringstream& os, const Container& v)
-{
- typename Container::const_iterator i = v.begin();
- os << '(';
- while (i < v.end()) {
- container_element_text_write (os, *i);
- if (++i >= v.end()) break;
- os << ',';
- }
- os << ')';
- return (os);
-}
-
-//----------------------------------------------------------------------
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uexception.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/uexception.cpp
deleted file mode 100644
index d00f219..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uexception.cpp
+++ /dev/null
@@ -1,305 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uexception.cc
-//
-
-#include "uassert.h"
-#include "uexception.h"
-#include "ustring.h"
-#include "mistream.h"
-#include "sostream.h"
-#include "strmsize.h"
-#include "uspecial.h"
-#include <errno.h>
-#if __GNUC__ >= 3 && !PLATFORM_ANDROID
- #include <cxxabi.h>
-#endif
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-
-/// \brief Returns a descriptive error message. fmt="%s"
-/// Overloads of this functions must set NULL as the default fmt
-/// argument and handle that case to provide a default format string
-/// in case the user does not have a localized one. The format
-/// string should be shown in the documentation to not require
-/// translators to look through code. Also, this function must
-/// not throw anything, so you must wrap memory allocation routines
-/// (like string::format, for instance) in a try{}catch(...){} block.
-///
-void exception::info (string& msgbuf, const char*) const throw()
-{
-#if PLATFORM_ANDROID
- msgbuf.format ("%s", what());
-#else /* !PLATFORM_ANDROID */
- try { msgbuf.format ("%s", what()); } catch (...) { /* Ignore all exceptions */ }
-#endif
-}
-
-/// Reads the exception from stream \p is.
-void exception::read (istream& is)
-{
- uint32_t stmSize;
- xfmt_t fmt;
- is >> fmt >> stmSize >> m_Backtrace;
- assert (fmt == m_Format && "The saved exception is of a different type.");
- assert (stmSize - exception::stream_size() <= is.remaining() && "The saved exception data is corrupt.");
- m_Format = fmt;
-}
-
-/// Writes the exception into stream \p os as an IFF chunk.
-void exception::write (ostream& os) const
-{
- os << m_Format << uint32_t(stream_size()) << m_Backtrace;
-}
-
-/// Writes the exception as text into stream \p os.
-void exception::text_write (ostringstream& os) const
-{
-#if !PLATFORM_ANDROID
- try {
-#endif
- string buf;
- info (buf);
- os << buf;
-#if !PLATFORM_ANDROID
- } catch (...) {}
-#endif
-}
-
-//----------------------------------------------------------------------
-
-/// Initializes the empty object. \p nBytes is the size of the attempted allocation.
-bad_alloc::bad_alloc (size_t nBytes) throw()
-: ustl::exception(),
- m_nBytesRequested (nBytes)
-{
- set_format (xfmt_BadAlloc);
-}
-
-/// Returns a descriptive error message. fmt="failed to allocate %d bytes"
-void bad_alloc::info (string& msgbuf, const char* fmt) const throw()
-{
- if (!fmt) fmt = "failed to allocate %d bytes";
-#if PLATFORM_ANDROID
- msgbuf.format (fmt, m_nBytesRequested);
-#else /* !PLATFORM_ANDROID */
- try { msgbuf.format (fmt, m_nBytesRequested); } catch (...) {}
-#endif
-}
-
-/// Reads the exception from stream \p is.
-void bad_alloc::read (istream& is)
-{
- ustl::exception::read (is);
- is >> m_nBytesRequested;
-}
-
-/// Writes the exception into stream \p os.
-void bad_alloc::write (ostream& os) const
-{
- ustl::exception::write (os);
- os << m_nBytesRequested;
-}
-
-/// Returns the size of the written exception.
-size_t bad_alloc::stream_size (void) const
-{
- return (ustl::exception::stream_size() + stream_size_of(m_nBytesRequested));
-}
-
-//----------------------------------------------------------------------
-
-/// Initializes the empty object. \p operation is the function that returned the error code.
-libc_exception::libc_exception (const char* operation) throw()
-: exception(),
- m_Errno (errno),
- m_Operation (operation)
-{
- set_format (xfmt_LibcException);
-}
-
-/// Copies object \p v.
-libc_exception::libc_exception (const libc_exception& v) throw()
-: exception (v),
- m_Errno (v.m_Errno),
- m_Operation (v.m_Operation)
-{
-}
-
-/// Copies object \p v.
-const libc_exception& libc_exception::operator= (const libc_exception& v)
-{
- m_Errno = v.m_Errno;
- m_Operation = v.m_Operation;
- return (*this);
-}
-
-/// Returns a descriptive error message. fmt="%s: %m"
-void libc_exception::info (string& msgbuf, const char* fmt) const throw()
-{
- if (!fmt) fmt = "%s: %m";
-#if PLATFORM_ANDROID
- msgbuf.format (fmt, m_Operation, m_Errno, m_Errno);
-#else /* !PLATFORM_ANDROID */
- try { msgbuf.format (fmt, m_Operation, m_Errno, m_Errno); } catch (...) {}
-#endif
-}
-
-/// Reads the exception from stream \p is.
-void libc_exception::read (istream& is)
-{
- exception::read (is);
- is >> m_Errno >> m_Operation;
-}
-
-/// Writes the exception into stream \p os.
-void libc_exception::write (ostream& os) const
-{
- exception::write (os);
- os << m_Errno << m_Operation;
-}
-
-/// Returns the size of the written exception.
-size_t libc_exception::stream_size (void) const
-{
- return (exception::stream_size() +
- stream_size_of(m_Errno) +
- stream_size_of(m_Operation));
-}
-
-//----------------------------------------------------------------------
-
-/// Initializes the empty object. \p operation is the function that returned the error code.
-file_exception::file_exception (const char* operation, const char* filename) throw()
-: libc_exception (operation)
-{
- memset (m_Filename, 0, VectorSize(m_Filename));
- set_format (xfmt_FileException);
- if (filename) {
- strncpy (m_Filename, filename, VectorSize(m_Filename));
- m_Filename [VectorSize(m_Filename) - 1] = 0;
- }
-}
-
-/// Returns a descriptive error message. fmt="%s %s: %m"
-void file_exception::info (string& msgbuf, const char* fmt) const throw()
-{
- if (!fmt) fmt = "%s %s: %m";
-#if PLATFORM_ANDROID
- msgbuf.format (fmt, m_Operation, m_Filename, m_Errno, m_Errno);
-#else /* !PLATFORM_ANDROID */
- try { msgbuf.format (fmt, m_Operation, m_Filename, m_Errno, m_Errno); } catch (...) {}
-#endif
-}
-
-/// Reads the exception from stream \p is.
-void file_exception::read (istream& is)
-{
- libc_exception::read (is);
- string filename;
- is >> filename;
- is.align (8);
- filename.copyto (filename, VectorSize(m_Filename));
-}
-
-/// Writes the exception into stream \p os.
-void file_exception::write (ostream& os) const
-{
- libc_exception::write (os);
- os << string (m_Filename);
- os.align (8);
-}
-
-/// Returns the size of the written exception.
-size_t file_exception::stream_size (void) const
-{
- return (libc_exception::stream_size() +
- Align (stream_size_of (string (m_Filename)), 8));
-}
-
-//----------------------------------------------------------------------
-
-/// \brief Uses C++ ABI call, if available to demangle the contents of \p buf.
-///
-/// The result is written to \p buf, with the maximum size of \p bufSize, and
-/// is zero-terminated. The return value is \p buf.
-///
-const char* demangle_type_name (char* buf, size_t bufSize, size_t* pdmSize)
-{
- size_t bl = strlen (buf);
-#if __GNUC__ >= 3 && !PLATFORM_ANDROID
- char dmname [256];
- size_t sz = VectorSize(dmname);
- int bFailed;
- abi::__cxa_demangle (buf, dmname, &sz, &bFailed);
- if (!bFailed) {
- bl = min (strlen (dmname), bufSize - 1);
- memcpy (buf, dmname, bl);
- buf[bl] = 0;
- }
-#else
- bl = min (bl, bufSize);
-#endif
- if (pdmSize)
- *pdmSize = bl;
- return (buf);
-}
-
-//----------------------------------------------------------------------
-
-/// Initializes the empty object. \p operation is the function that returned the error code.
-stream_bounds_exception::stream_bounds_exception (const char* operation, const char* type, uoff_t offset, size_t expected, size_t remaining) throw()
-: libc_exception (operation),
- m_TypeName (type),
- m_Offset (offset),
- m_Expected (expected),
- m_Remaining (remaining)
-{
- set_format (xfmt_StreamBoundsException);
-}
-
-/// Returns a descriptive error message. fmt="%s stream %s: @%u: expected %u, available %u";
-void stream_bounds_exception::info (string& msgbuf, const char* fmt) const throw()
-{
- char typeName [256];
- strncpy (typeName, m_TypeName, VectorSize(typeName));
- typeName[VectorSize(typeName)-1] = 0;
- if (!fmt) fmt = "%s stream %s: @0x%X: need %u bytes, have %u";
-#if PLATFORM_ANDROID
- msgbuf.format (fmt, demangle_type_name (VectorBlock(typeName)), m_Operation, m_Offset, m_Expected, m_Remaining);
-#else /* !PLATFORM_ANDROID */
- try { msgbuf.format (fmt, demangle_type_name (VectorBlock(typeName)), m_Operation, m_Offset, m_Expected, m_Remaining); } catch (...) {}
-#endif
-}
-
-/// Reads the exception from stream \p is.
-void stream_bounds_exception::read (istream& is)
-{
- libc_exception::read (is);
- is >> m_TypeName >> m_Offset >> m_Expected >> m_Remaining;
-}
-
-/// Writes the exception into stream \p os.
-void stream_bounds_exception::write (ostream& os) const
-{
- libc_exception::write (os);
- os << m_TypeName << m_Offset << m_Expected << m_Remaining;
-}
-
-/// Returns the size of the written exception.
-size_t stream_bounds_exception::stream_size (void) const
-{
- return (libc_exception::stream_size() +
- stream_size_of(m_TypeName) +
- stream_size_of(m_Offset) +
- stream_size_of(m_Expected) +
- stream_size_of(m_Remaining));
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uexception.h b/media/libdrm/mobile2/src/util/ustl-1.0/uexception.h
deleted file mode 100644
index 3e9a179..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uexception.h
+++ /dev/null
@@ -1,194 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uexception.h
-//
-// This file contains stuff from \<exception\>.
-// The standard C++ headers are duplicated because uSTL is intended
-// to completely replace all C++ standard library functions.
-//
-
-#ifndef UEXCEPTION_H_18DE3EF55C4F00673268F0D66546AF5D
-#define UEXCEPTION_H_18DE3EF55C4F00673268F0D66546AF5D
-
-#include "utypes.h"
-#ifndef WITHOUT_LIBSTDCPP
- #include <exception>
- #include <new>
-#endif
-#include "bktrace.h"
-
-#ifdef WITHOUT_LIBSTDCPP // This code is copied from <exception>
-namespace std {
-/// If you write a replacement terminate handler, it must be of this type.
-typedef void (*terminate_handler) (void);
-/// If you write a replacement unexpected handler, it must be of this type.
-typedef void (*unexpected_handler) (void);
-/// Takes a new handler function as an argument, returns the old function.
-terminate_handler set_terminate (terminate_handler pHandler) throw();
-/// The runtime will call this function if exception handling must be
-/// abandoned for any reason. It can also be called by the user.
-void terminate (void) __attribute__ ((__noreturn__));
-/// Takes a new handler function as an argument, returns the old function.
-unexpected_handler set_unexpected (unexpected_handler pHandler) throw();
-/// The runtime will call this function if an exception is thrown which
-/// violates the function's exception specification.
-void unexpected (void) __attribute__ ((__noreturn__));
-/// Returns true when the caught exception violates the throw specification.
-bool uncaught_exception() throw();
-} // namespace std
-#endif
-
-namespace ustl {
-
-class string;
-
-typedef uint32_t xfmt_t;
-
-enum {
- xfmt_Exception,
- xfmt_BadAlloc,
- xfmt_LibcException = 12,
- xfmt_FileException = 13,
- xfmt_StreamBoundsException = 14
-};
-
-/// \class exception uexception.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Base class for exceptions, equivalent to std::exception.
-///
-#ifdef WITHOUT_LIBSTDCPP
-class exception {
-#else
-class exception : public std::exception {
-#endif
-public:
- typedef const CBacktrace& rcbktrace_t;
-public:
- inline exception (void) throw() : m_Format (xfmt_Exception) {}
- inline virtual ~exception (void) throw() {}
- inline virtual const char* what (void) const throw() { return ("error"); }
- virtual void info (string& msgbuf, const char* fmt = NULL) const throw();
- virtual void read (istream& is);
- virtual void write (ostream& os) const;
- void text_write (ostringstream& os) const;
- inline virtual size_t stream_size (void) const { return (sizeof(m_Format) + sizeof(uint32_t) + m_Backtrace.stream_size()); }
- /// Format of the exception is used to lookup exception::info format string.
- /// Another common use is the instantiation of serialized exceptions, used
- /// by the error handler node chain to troubleshoot specific errors.
- inline xfmt_t format (void) const { return (m_Format); }
- inline rcbktrace_t backtrace (void) const { return (m_Backtrace); }
-protected:
- inline void set_format (xfmt_t fmt) { m_Format = fmt; }
-private:
- CBacktrace m_Backtrace; ///< Backtrace of the throw point.
- xfmt_t m_Format; ///< Format of the exception's data.
-};
-
-/// \class bad_cast uexception.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Thrown to indicate a bad dynamic_cast usage.
-///
-class bad_cast : public exception {
-public:
- inline explicit bad_cast (void) throw() : exception() {}
- inline virtual const char* what (void) const throw() { return ("bad cast"); }
-};
-
-//----------------------------------------------------------------------
-
-/// \class bad_alloc uexception.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Exception thrown on memory allocation failure by memblock::reserve.
-///
-#ifdef WITHOUT_LIBSTDCPP
-class bad_alloc : public exception {
-#else
-class bad_alloc : public std::bad_alloc, public exception {
-#endif
-public:
- explicit bad_alloc (size_t nBytes = 0) throw();
- inline virtual const char* what (void) const throw() { return ("memory allocation failed"); }
- virtual void info (string& msgbuf, const char* fmt = NULL) const throw();
- virtual void read (istream& is);
- virtual void write (ostream& os) const;
- virtual size_t stream_size (void) const;
-protected:
- size_t m_nBytesRequested; ///< Number of bytes requested by the failed allocation.
-};
-
-/// \class libc_exception uexception.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Thrown when a libc function returns an error.
-///
-/// Contains an errno and description. This is a uSTL extension.
-///
-class libc_exception : public exception {
-public:
- explicit libc_exception (const char* operation) throw();
- libc_exception (const libc_exception& v) throw();
- const libc_exception& operator= (const libc_exception& v);
- inline virtual const char* what (void) const throw() { return ("libc function failed"); }
- virtual void info (string& msgbuf, const char* fmt = NULL) const throw();
- virtual void read (istream& is);
- virtual void write (ostream& os) const;
- virtual size_t stream_size (void) const;
-protected:
- intptr_t m_Errno; ///< Error code returned by the failed operation.
- const char* m_Operation; ///< Name of the failed operation.
-};
-
-/// \class file_exception uexception.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief File-related exceptions.
-///
-/// Contains the file name. This is a uSTL extension.
-///
-class file_exception : public libc_exception {
-public:
- file_exception (const char* operation, const char* filename) throw();
- inline virtual const char* what (void) const throw() { return ("file error"); }
- virtual void info (string& msgbuf, const char* fmt = NULL) const throw();
- virtual void read (istream& is);
- virtual void write (ostream& os) const;
- virtual size_t stream_size (void) const;
-protected:
- char m_Filename [PATH_MAX]; ///< Name of the file causing the error.
-};
-
-/// \class stream_bounds_exception uexception.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Stream bounds checking.
-///
-/// Only thrown in debug builds unless you say otherwise in config.h
-/// This is a uSTL extension.
-///
-class stream_bounds_exception : public libc_exception {
-public:
- stream_bounds_exception (const char* operation, const char* type, uoff_t offset, size_t expected, size_t remaining) throw();
- inline virtual const char* what (void) const throw() { return ("stream bounds exception"); }
- virtual void info (string& msgbuf, const char* fmt = NULL) const throw();
- virtual void read (istream& is);
- virtual void write (ostream& os) const;
- virtual size_t stream_size (void) const;
-protected:
- const char* m_TypeName;
- uoff_t m_Offset;
- size_t m_Expected;
- size_t m_Remaining;
-};
-
-const char* demangle_type_name (char* buf, size_t bufSize, size_t* pdmSize = NULL);
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ufunction.h b/media/libdrm/mobile2/src/util/ustl-1.0/ufunction.h
deleted file mode 100644
index 53dc5e2..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ufunction.h
+++ /dev/null
@@ -1,480 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// \file ufunction.h
-//
-// \brief Implements STL standard functors.
-//
-// See STL specification and bvts for usage of these. The only
-// extension is the mem_var functors for member variable access:
-// \code
-// f = find_if (ctr, mem_var_equal_to(&MyClass::m_Var, matchVar));
-// f = find_if (ctr, mem_var_less(&MyClass::m_Var, matchVar));
-// \endcode
-// There are a couple of others but the syntax is much harder to grasp.
-// See bvt10.cc for more examples.
-//
-
-#ifndef UFUNCTION_H_221ABA8551801799263C927234C085F3
-#define UFUNCTION_H_221ABA8551801799263C927234C085F3
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-// Standard functors
-//----------------------------------------------------------------------
-
-/// \brief void-returning function abstract interface.
-/// \ingroup FunctorObjects
-template <typename Result>
-struct void_function {
- typedef Result result_type;
-};
-
-/// \brief \p Result f (\p Arg) function abstract interface.
-/// \ingroup FunctorObjects
-template <typename Arg, typename Result>
-struct unary_function {
- typedef Arg argument_type;
- typedef Result result_type;
-};
-
-/// \brief \p Result f (\p Arg1, \p Arg2) function abstract interface.
-/// \ingroup FunctorObjects
-template <typename Arg1, typename Arg2, typename Result>
-struct binary_function {
- typedef Arg1 first_argument_type;
- typedef Arg2 second_argument_type;
- typedef Result result_type;
-};
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-
-#define STD_BINARY_FUNCTOR(name, rv, func) \
-template <class T> struct name : public binary_function<T,T,rv> \
-{ inline rv operator()(const T& a, const T& b) const { return func; } };
-#define STD_UNARY_FUNCTOR(name, rv, func) \
-template <class T> struct name : public unary_function<T,rv> \
-{ inline rv operator()(const T& a) const { return func; } };
-#define STD_CONVERSION_FUNCTOR(name, func) \
-template <class S, class D> struct name : public unary_function<S,D> \
-{ inline D operator()(const S& a) const { return func; } };
-
-STD_BINARY_FUNCTOR (plus, T, (a + b))
-STD_BINARY_FUNCTOR (minus, T, (a - b))
-STD_BINARY_FUNCTOR (divides, T, (a / b))
-STD_BINARY_FUNCTOR (modulus, T, (a % b))
-STD_BINARY_FUNCTOR (multiplies, T, (a * b))
-STD_BINARY_FUNCTOR (logical_and, T, (a && b))
-STD_BINARY_FUNCTOR (logical_or, T, (a || b))
-STD_UNARY_FUNCTOR (logical_not, T, (!a))
-STD_BINARY_FUNCTOR (bitwise_or, T, (a | b))
-STD_BINARY_FUNCTOR (bitwise_and, T, (a & b))
-STD_BINARY_FUNCTOR (bitwise_xor, T, (a ^ b))
-STD_UNARY_FUNCTOR (bitwise_not, T, (~a))
-STD_UNARY_FUNCTOR (negate, T, (-a))
-STD_BINARY_FUNCTOR (equal_to, bool, (a == b))
-STD_BINARY_FUNCTOR (not_equal_to, bool, (!(a == b)))
-STD_BINARY_FUNCTOR (greater, bool, (b < a))
-STD_BINARY_FUNCTOR (less, bool, (a < b))
-STD_BINARY_FUNCTOR (greater_equal, bool, (!(a < b)))
-STD_BINARY_FUNCTOR (less_equal, bool, (!(b < a)))
-STD_BINARY_FUNCTOR (compare, int, (a < b ? -1 : (b < a)))
-STD_UNARY_FUNCTOR (identity, T, (a))
-
-#endif // DOXYGEN_SHOULD_SKIP_THIS
-
-/// \brief Selects and returns the first argument.
-/// \ingroup FunctorObjects
-template <class T1, class T2> struct project1st : public binary_function<T1,T2,T1> { inline const T1& operator()(const T1& a, const T2&) const { return (a); } };
-/// \brief Selects and returns the second argument.
-/// \ingroup FunctorObjects
-template <class T1, class T2> struct project2nd : public binary_function<T1,T2,T2> { inline const T2& operator()(const T1&, const T2& a) const { return (a); } };
-
-//----------------------------------------------------------------------
-// Generic function to functor converters.
-//----------------------------------------------------------------------
-
-/// \brief Wrapper object for unary function pointers.
-/// Use the \ref ptr_fun accessor to create this object.
-/// \ingroup FunctorObjects
-template <typename Arg, typename Result>
-class pointer_to_unary_function : public unary_function<Arg,Result> {
-public:
- typedef Arg argument_type;
- typedef Result result_type;
- typedef Result (*pfunc_t)(Arg);
-public:
- explicit inline pointer_to_unary_function (pfunc_t pfn) : m_pfn (pfn) {}
- inline result_type operator() (argument_type v) const { return (m_pfn(v)); }
-private:
- pfunc_t m_pfn; ///< Pointer to the wrapped function.
-};
-
-/// \brief Wrapper object for binary function pointers.
-/// Use the \ref ptr_fun accessor to create this object.
-/// \ingroup FunctorObjects
-template <typename Arg1, typename Arg2, typename Result>
-class pointer_to_binary_function : public binary_function<Arg1,Arg2,Result> {
-public:
- typedef Arg1 first_argument_type;
- typedef Arg2 second_argument_type;
- typedef Result result_type;
- typedef Result (*pfunc_t)(Arg1, Arg2);
-public:
- explicit inline pointer_to_binary_function (pfunc_t pfn) : m_pfn (pfn) {}
- inline result_type operator() (first_argument_type v1, second_argument_type v2) const { return (m_pfn(v1, v2)); }
-private:
- pfunc_t m_pfn; ///< Pointer to the wrapped function.
-};
-
-/// ptr_fun(pfn) wraps function pointer pfn into a functor class that calls it.
-/// \ingroup FunctorAccessors
-template <typename Arg, typename Result>
-inline pointer_to_unary_function<Arg,Result> ptr_fun (Result (*pfn)(Arg))
-{
- return (pointer_to_unary_function<Arg,Result> (pfn));
-}
-
-/// ptr_fun(pfn) wraps function pointer pfn into a functor class that calls it.
-/// \ingroup FunctorAccessors
-template <typename Arg1, typename Arg2, typename Result>
-inline pointer_to_binary_function<Arg1,Arg2,Result> ptr_fun (Result (*pfn)(Arg1,Arg2))
-{
- return (pointer_to_binary_function<Arg1,Arg2,Result> (pfn));
-}
-
-//----------------------------------------------------------------------
-// Negators.
-//----------------------------------------------------------------------
-
-/// \brief Wraps a unary function to return its logical negative.
-/// Use the \ref unary_negator accessor to create this object.
-/// \ingroup FunctorObjects
-template <class UnaryFunction>
-class unary_negate : public unary_function<typename UnaryFunction::argument_type,
- typename UnaryFunction::result_type> {
-public:
- typedef typename UnaryFunction::argument_type argument_type;
- typedef typename UnaryFunction::result_type result_type;
-public:
- explicit inline unary_negate (UnaryFunction pfn) : m_pfn (pfn) {}
- inline result_type operator() (argument_type v) const { return (!m_pfn(v)); }
-private:
- UnaryFunction m_pfn;
-};
-
-/// Returns the functor that negates the result of *pfn().
-/// \ingroup FunctorAccessors
-template <class UnaryFunction>
-inline unary_negate<UnaryFunction> unary_negator (UnaryFunction pfn)
-{
- return (unary_negate<UnaryFunction>(pfn));
-}
-
-//----------------------------------------------------------------------
-// Argument binders
-//----------------------------------------------------------------------
-
-/// \brief Converts a binary function to a unary function
-/// by binding a constant value to the first argument.
-/// Use the \ref bind1st accessor to create this object.
-/// \ingroup FunctorObjects
-template <class BinaryFunction>
-class binder1st : public unary_function<typename BinaryFunction::second_argument_type,
- typename BinaryFunction::result_type> {
-public:
- typedef typename BinaryFunction::first_argument_type arg1_t;
- typedef typename BinaryFunction::second_argument_type arg2_t;
- typedef typename BinaryFunction::result_type result_t;
-public:
- inline binder1st (const BinaryFunction& pfn, const arg1_t& v) : m_pfn (pfn), m_Value(v) {}
- inline result_t operator()(arg2_t v2) const { return (m_pfn (m_Value, v2)); }
-protected:
- BinaryFunction m_pfn;
- arg1_t m_Value;
-};
-
-/// \brief Converts a binary function to a unary function
-/// by binding a constant value to the second argument.
-/// Use the \ref bind2nd accessor to create this object.
-/// \ingroup FunctorObjects
-template <class BinaryFunction>
-class binder2nd : public unary_function<typename BinaryFunction::first_argument_type,
- typename BinaryFunction::result_type> {
-public:
- typedef typename BinaryFunction::first_argument_type arg1_t;
- typedef typename BinaryFunction::second_argument_type arg2_t;
- typedef typename BinaryFunction::result_type result_t;
-public:
- inline binder2nd (const BinaryFunction& pfn, const arg2_t& v) : m_pfn (pfn), m_Value(v) {}
- inline result_t operator()(arg1_t v1) const { return (m_pfn (v1, m_Value)); }
-protected:
- BinaryFunction m_pfn;
- arg2_t m_Value;
-};
-
-/// Converts \p pfn into a unary function by binding the first argument to \p v.
-/// \ingroup FunctorAccessors
-template <typename BinaryFunction>
-inline binder1st<BinaryFunction>
-bind1st (BinaryFunction pfn, typename BinaryFunction::first_argument_type v)
-{
- return (binder1st<BinaryFunction> (pfn, v));
-}
-
-/// Converts \p pfn into a unary function by binding the second argument to \p v.
-/// \ingroup FunctorAccessors
-template <typename BinaryFunction>
-inline binder2nd<BinaryFunction>
-bind2nd (BinaryFunction pfn, typename BinaryFunction::second_argument_type v)
-{
- return (binder2nd<BinaryFunction> (pfn, v));
-}
-
-//----------------------------------------------------------------------
-// Composition adapters
-//----------------------------------------------------------------------
-
-/// \brief Chains two unary functions together.
-///
-/// When f(x) and g(x) are composed, the result is function c(x)=f(g(x)).
-/// Use the \ref compose1 accessor to create this object.
-/// This template is an extension, implemented by SGI STL and uSTL.
-/// \ingroup FunctorObjects
-///
-template <typename Operation1, typename Operation2>
-class unary_compose : public unary_function<typename Operation2::argument_type,
- typename Operation1::result_type> {
-public:
- typedef typename Operation2::argument_type arg_t;
- typedef const arg_t& rcarg_t;
- typedef typename Operation1::result_type result_t;
-public:
- inline unary_compose (const Operation1& f, const Operation2& g) : m_f(f), m_g(g) {}
- inline result_t operator() (rcarg_t x) const { return m_f(m_g(x)); }
-protected:
- Operation1 m_f; ///< f(x), if c(x) = f(g(x))
- Operation2 m_g; ///< g(x), if c(x) = f(g(x))
-};
-
-/// Creates a \ref unary_compose object whose function c(x)=f(g(x))
-/// \ingroup FunctorAccessors
-template <typename Operation1, typename Operation2>
-inline unary_compose<Operation1, Operation2>
-compose1 (const Operation1& f, const Operation2& g)
-{ return unary_compose<Operation1,Operation2>(f, g); }
-
-/// \brief Chains two unary functions through a binary function.
-///
-/// When f(x,y), g(x), and h(x) are composed, the result is function
-/// c(x)=f(g(x),h(x)). Use the \ref compose2 accessor to create this
-/// object. This template is an extension, implemented by SGI STL and uSTL.
-/// \ingroup FunctorObjects
-///
-template <typename Operation1, typename Operation2, typename Operation3>
-class binary_compose : public unary_function<typename Operation2::argument_type,
- typename Operation1::result_type> {
-public:
- typedef typename Operation2::argument_type arg_t;
- typedef const arg_t& rcarg_t;
- typedef typename Operation1::result_type result_t;
-public:
- inline binary_compose (const Operation1& f, const Operation2& g, const Operation3& h) : m_f(f), m_g(g), m_h(h) {}
- inline result_t operator() (rcarg_t x) const { return m_f(m_g(x), m_h(x)); }
-protected:
- Operation1 m_f; ///< f(x,y), if c(x) = f(g(x),h(x))
- Operation2 m_g; ///< g(x), if c(x) = f(g(x),h(x))
- Operation3 m_h; ///< h(x), if c(x) = f(g(x),h(x))
-};
-
-/// Creates a \ref binary_compose object whose function c(x)=f(g(x),h(x))
-/// \ingroup FunctorAccessors
-template <typename Operation1, typename Operation2, typename Operation3>
-inline binary_compose<Operation1, Operation2, Operation3>
-compose2 (const Operation1& f, const Operation2& g, const Operation3& h)
-{ return binary_compose<Operation1, Operation2, Operation3> (f, g, h); }
-
-//----------------------------------------------------------------------
-// Member function adaptors
-//----------------------------------------------------------------------
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-
-#define MEM_FUN_T(WrapperName, ClassName, ArgType, FuncType, CallType) \
- template <typename Ret, class T> \
- class ClassName : public unary_function<ArgType,Ret> { \
- public: \
- typedef Ret (T::*func_t) FuncType; \
- public: \
- explicit inline ClassName (func_t pf) : m_pf (pf) {} \
- inline Ret operator() (ArgType p) const { return ((p CallType m_pf)()); } \
- private: \
- func_t m_pf; \
- }; \
- \
- template <class Ret, typename T> \
- inline ClassName<Ret,T> WrapperName (Ret (T::*pf) FuncType) \
- { \
- return (ClassName<Ret,T> (pf)); \
- }
-
-MEM_FUN_T(mem_fun, mem_fun_t, T*, (void), ->*)
-MEM_FUN_T(mem_fun, const_mem_fun_t, const T*, (void) const, ->*)
-MEM_FUN_T(mem_fun_ref, mem_fun_ref_t, T&, (void), .*)
-MEM_FUN_T(mem_fun_ref, const_mem_fun_ref_t, const T&, (void) const, .*)
-
-#define EXT_MEM_FUN_T(ClassName, HostType, FuncType) \
- template <class T, typename Ret, typename V> \
- class ClassName : public unary_function<V,void> { \
- public: \
- typedef Ret (T::*func_t)(V) FuncType; \
- public: \
- inline ClassName (HostType t, func_t pf) : m_t (t), m_pf (pf) {} \
- inline Ret operator() (V v) const { return ((m_t->*m_pf)(v)); } \
- private: \
- HostType m_t; \
- func_t m_pf; \
- }; \
- \
- template <class T, typename Ret, typename V> \
- inline ClassName<T,Ret,V> mem_fun (HostType p, Ret (T::*pf)(V) FuncType) \
- { \
- return (ClassName<T,Ret,V> (p, pf)); \
- }
-
-EXT_MEM_FUN_T(ext_mem_fun_t, T*, )
-EXT_MEM_FUN_T(const_ext_mem_fun_t, const T*, const)
-
-#endif // DOXYGEN_SHOULD_SKIP_THIS
-
-//----------------------------------------------------------------------
-// Member variable adaptors (uSTL extension)
-//----------------------------------------------------------------------
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-
-#define MEM_VAR_T(FunctorName, ArgType, VarType, BaseClass, CallImpl) \
- template <typename Function, class T, typename VT> \
- class FunctorName##_t : public BaseClass { \
- public: \
- typedef ArgType argument_type; \
- typedef typename Function::result_type result_type; \
- typedef VarType mem_var_ptr_t; \
- public: \
- inline FunctorName##_t (mem_var_ptr_t pv, Function pfn) : m_pv(pv), m_pfn(pfn) {} \
- inline result_type operator() CallImpl \
- private: \
- mem_var_ptr_t m_pv; \
- Function m_pfn; \
- }; \
- \
- template <typename Function, class T, typename VT> \
- inline FunctorName##_t<Function, T, VT> \
- FunctorName (VT T::*mvp, Function pfn) \
- { \
- return (FunctorName##_t<Function,T,VT> (mvp, pfn)); \
- }
-
-#define FUNCTOR_UNARY_BASE(ArgType) unary_function<ArgType, typename Function::result_type>
-#define FUNCTOR_BINARY_BASE(ArgType) binary_function<ArgType, ArgType, typename Function::result_type>
-
-#define MEM_VAR_UNARY_ARGS (argument_type p) const \
- { return (m_pfn(p.*m_pv)); }
-#define MEM_VAR_BINARY_ARGS (argument_type p1, argument_type p2) const \
- { return (m_pfn(p1.*m_pv, p2.*m_pv)); }
-
-MEM_VAR_T(mem_var1, T&, VT T::*, FUNCTOR_UNARY_BASE(T&), MEM_VAR_UNARY_ARGS)
-MEM_VAR_T(const_mem_var1, const T&, const VT T::*, FUNCTOR_UNARY_BASE(T&), MEM_VAR_UNARY_ARGS)
-MEM_VAR_T(mem_var2, T&, VT T::*, FUNCTOR_BINARY_BASE(T&), MEM_VAR_BINARY_ARGS)
-MEM_VAR_T(const_mem_var2, const T&, const VT T::*, FUNCTOR_BINARY_BASE(T&), MEM_VAR_BINARY_ARGS)
-
-#undef MEM_VAR_UNARY_ARGS
-#undef MEM_VAR_BINARY_ARGS
-
-#endif // DOXYGEN_SHOULD_SKIP_THIS
-
-/// Returned functor passes member variable \p mvp reference of given object to equal\<VT\>.
-/// \ingroup FunctorAccessors
-template <class T, typename VT>
-inline const_mem_var1_t<binder2nd<equal_to<VT> >, T, VT>
-mem_var_equal_to (const VT T::*mvp, const VT& v)
-{
- return (const_mem_var1_t<binder2nd<equal_to<VT> >,T,VT> (mvp, bind2nd(equal_to<VT>(), v)));
-}
-
-/// Returned functor passes member variable \p mvp reference of given object to less\<VT\>.
-/// \ingroup FunctorAccessors
-template <class T, typename VT>
-inline const_mem_var1_t<binder2nd<less<VT> >, T, VT>
-mem_var_less (const VT T::*mvp, const VT& v)
-{
- return (const_mem_var1_t<binder2nd<less<VT> >,T,VT> (mvp, bind2nd(less<VT>(), v)));
-}
-
-/// Returned functor passes member variable \p mvp reference of given object to equal\<VT\>.
-/// \ingroup FunctorAccessors
-template <class T, typename VT>
-inline const_mem_var2_t<equal_to<VT>, T, VT>
-mem_var_equal_to (const VT T::*mvp)
-{
- return (const_mem_var2_t<equal_to<VT>,T,VT> (mvp, equal_to<VT>()));
-}
-
-/// Returned functor passes member variable \p mvp reference of given object to less\<VT\>.
-/// \ingroup FunctorAccessors
-template <class T, typename VT>
-inline const_mem_var2_t<less<VT>, T, VT>
-mem_var_less (const VT T::*mvp)
-{
- return (const_mem_var2_t<less<VT>,T,VT> (mvp, less<VT>()));
-}
-
-//----------------------------------------------------------------------
-// Dereference adaptors (uSTL extension)
-//----------------------------------------------------------------------
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-
-#define DEREFERENCER_T(ClassName, ArgType, BaseClass, CallImpl, FunctorKey) \
- template <typename T, typename Function> \
- class ClassName : public BaseClass { \
- public: \
- typedef ArgType* argument_type; \
- typedef typename Function::result_type result_type; \
- public: \
- inline ClassName (Function pfn) : m_pfn (pfn) {} \
- inline result_type operator() CallImpl \
- private: \
- Function m_pfn; \
- }; \
- \
- template <typename T, typename Function> \
- inline ClassName<T,Function> _dereference (Function pfn, FunctorKey) \
- { \
- return (ClassName<T,Function> (pfn)); \
- }
-
-#define DEREF_UNARY_ARGS (argument_type p) const \
- { return (m_pfn(*p)); }
-#define DEREF_BINARY_ARGS (argument_type p1, argument_type p2) const \
- { return (m_pfn(*p1, *p2)); }
-
-DEREFERENCER_T(deref1_t, T, FUNCTOR_UNARY_BASE(T*), DEREF_UNARY_ARGS, FUNCTOR_UNARY_BASE(T))
-DEREFERENCER_T(const_deref1_t, const T, FUNCTOR_UNARY_BASE(const T*), DEREF_UNARY_ARGS, FUNCTOR_UNARY_BASE(const T))
-DEREFERENCER_T(deref2_t, T, FUNCTOR_BINARY_BASE(T*), DEREF_BINARY_ARGS, FUNCTOR_BINARY_BASE(T))
-DEREFERENCER_T(const_deref2_t, const T, FUNCTOR_BINARY_BASE(const T*), DEREF_BINARY_ARGS, FUNCTOR_BINARY_BASE(const T))
-
-#define dereference(f) _dereference(f,f)
-
-#undef DEREF_UNARY_ARGS
-#undef DEREF_BINARY_ARGS
-
-#endif
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uheap.h b/media/libdrm/mobile2/src/util/ustl-1.0/uheap.h
deleted file mode 100644
index 9dfddaf..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uheap.h
+++ /dev/null
@@ -1,153 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uheap.h
-//
-// Implementation of STL heap algorithms.
-//
-// The function prototypes are copied
-// exactly from the SGI version of STL documentation along with comments about
-// their use. The code is NOT the same, though the functionality is.
-//
-
-#ifndef UHEAP_H_574B9EAF271A1C107190B4D575A356C5
-#define UHEAP_H_574B9EAF271A1C107190B4D575A356C5
-
-#include "uvector.h"
-#include "ualgobase.h"
-
-namespace ustl {
-
-/// \brief Returns true if the given range is a heap under \p comp.
-/// A heap is a sequentially encoded binary tree where for every node
-/// comp(node,child1) is false and comp(node,child2) is false.
-/// \ingroup HeapAlgorithms
-/// \ingroup ConditionAlgorithms
-///
-template <typename RandomAccessIterator, typename Compare>
-bool is_heap (RandomAccessIterator first, RandomAccessIterator last, Compare comp)
-{
- RandomAccessIterator iChild (first);
- for (; ++iChild < last; ++first)
- if (comp (*first, *iChild) || (++iChild < last && comp (*first, *iChild)))
- return (false);
- return (true);
-}
-
-/// \brief make_heap turns the range [first, last) into a heap
-/// At completion, is_heap (first, last, comp) is true.
-/// The algorithm is adapted from "Classic Data Structures in C++" by Timothy Budd.
-/// \ingroup HeapAlgorithms
-/// \ingroup SortingAlgorithms
-///
-template <typename RandomAccessIterator, typename Compare>
-void make_heap (RandomAccessIterator first, RandomAccessIterator last, Compare comp)
-{
- typedef typename iterator_traits<RandomAccessIterator>::value_type value_type;
- const value_type v (*first);
- uoff_t iChild, iHole = 0, iEnd (distance (first, last));
- while ((iChild = 2 * iHole + 1) < iEnd) {
- if (iChild + 1 < iEnd) // Pick the greater child
- iChild += comp (first[iChild], first[iChild + 1]);
- if (comp (first[iChild], v))
- break; // Done when parent is greater than both children.
- first[iHole] = first[iChild];
- iHole = iChild;
- }
- if (iHole < iEnd)
- first[iHole] = v;
-}
-
-/// \brief Inserts the *--last into the preceeding range assumed to be a heap.
-/// \ingroup HeapAlgorithms
-/// \ingroup MutatingAlgorithms
-template <typename RandomAccessIterator, typename Compare>
-void push_heap (RandomAccessIterator first, RandomAccessIterator last, Compare comp)
-{
- if (last <= first)
- return;
- typedef typename iterator_traits<RandomAccessIterator>::value_type value_type;
- const value_type v (*--last);
- while (first < last) {
- RandomAccessIterator iParent = first + (distance(first, last) - 1) / 2;
- if (comp (v, *iParent))
- break;
- *last = *iParent;
- last = iParent;
- }
- *last = v;
-}
-
-/// Removes the largest element from the heap (*first) and places it at *(last-1)
-/// [first, last-1) is a heap after this operation.
-/// \ingroup HeapAlgorithms
-/// \ingroup MutatingAlgorithms
-template <typename RandomAccessIterator, typename Compare>
-void pop_heap (RandomAccessIterator first, RandomAccessIterator last, Compare comp)
-{
- if (--last <= first)
- return;
- iter_swap (first, last);
- make_heap (first, last, comp);
-}
-
-/// Sorts heap [first, last) in descending order according to comp.
-/// \ingroup HeapAlgorithms
-/// \ingroup SortingAlgorithms
-template <typename RandomAccessIterator, typename Compare>
-void sort_heap (RandomAccessIterator first, RandomAccessIterator last, Compare comp)
-{
- for (; first < last; --last)
- pop_heap (first, last, comp);
-}
-
-#define HEAP_FN_WITH_LESS(rtype, name) \
-template <typename RandomAccessIterator>\
-inline rtype name (RandomAccessIterator first, RandomAccessIterator last) \
-{ \
- typedef typename iterator_traits<RandomAccessIterator>::value_type value_type; \
- return (name (first, last, less<value_type>())); \
-}
-HEAP_FN_WITH_LESS (bool, is_heap)
-HEAP_FN_WITH_LESS (void, make_heap)
-HEAP_FN_WITH_LESS (void, push_heap)
-HEAP_FN_WITH_LESS (void, pop_heap)
-HEAP_FN_WITH_LESS (void, sort_heap)
-#undef HEAP_FN_WITH_LESS
-
-/// \class priority_queue uheap.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief Sorted queue adapter to uSTL containers.
-///
-/// Acts just like the queue adapter, but keeps the elements sorted by priority
-/// specified by the given comparison operator.
-///
-template <typename T, typename Ctr = vector<T>, typename Comp = less<typename Ctr::value_type> >
-class priority_queue {
-public:
- typedef Ctr base_ctr;
- typedef typename base_ctr::value_type value_type;
- typedef typename base_ctr::size_type size_type;
- typedef typename base_ctr::const_pointer const_pointer;
- typedef typename base_ctr::const_reference reference;
-public:
- priority_queue (const Comp& c = Comp()) : m_v(), m_c (c) {}
- priority_queue (const_pointer f, const_pointer l, const Comp& c = Comp())
- : m_v (f, l), m_c (c) { make_heap (m_v.begin(), m_v.end(), m_c); }
- inline size_type size (void) const { return (m_v.size()); }
- inline bool empty (void) const { return (m_v.empty()); }
- inline reference top (void) const { return (m_v.at(0)); }
- inline void push (reference v) { m_v.push_back (v); make_heap (m_v.begin(), m_v.end(), m_c); }
- inline void pop (void) { pop_heap (m_v.begin(), m_v.end()); m_v.pop_back(); }
-private:
- base_ctr m_v; ///< Element container.
- Comp m_c; ///< Comparison functor by value.
-};
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uios.h b/media/libdrm/mobile2/src/util/ustl-1.0/uios.h
deleted file mode 100644
index 6153be5..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uios.h
+++ /dev/null
@@ -1,107 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uios.h
-//
-// Types used by the streams for option setting.
-//
-
-#ifndef UIOS_H_630C16E316F7650E3A02E1C6611B789A
-#define UIOS_H_630C16E316F7650E3A02E1C6611B789A
-
-#include "utypes.h"
-
-namespace ustl {
-
-class file_exception;
-
-const char endl = '\n'; ///< End of line character.
-const char ends = '\0'; ///< End of string character.
-
-/// Defines types and constants used by all stream classes.
-class ios_base {
-public:
- /// Used to set parameters for stringstreams
- enum fmtflags {
- boolalpha = (1 << 0), ///< Boolean values printed as text.
- dec = (1 << 1), ///< Decimal number output.
- fixed = (1 << 2), ///< Fixed-point float output.
- hex = (1 << 3), ///< Hexadecimal number output.
- internal = (1 << 4),
- left = (1 << 5), ///< Left alignment.
- oct = (1 << 6), ///< Octal number output.
- right = (1 << 7), ///< Right alignment.
- scientific = (1 << 8), ///< Scientific float format.
- showbase = (1 << 9), ///< Add 0x or 0 prefixes on hex and octal numbers.
- showpoint = (1 << 10), ///< Print decimal point.
- showpos = (1 << 11),
- skipws = (1 << 12), ///< Skip whitespace when reading.
- unitbuf = (1 << 13),
- uppercase = (1 << 14),
- adjustfield = (1 << 15),
- basefield = (1 << 16),
- floatfield = (1 << 17)
- };
- /// For file-based streams, specifies fd mode.
- enum openmode_bits {
- in = (1 << 0),
- out = (1 << 1),
- app = (1 << 2),
- ate = (1 << 3),
- binary = (1 << 4),
- trunc = (1 << 5),
- #ifndef DOXYGEN_SHOULD_SKIP_THIS
- nonblock= (1 << 6),
- nocreate= (1 << 7),
- noctty = (1 << 8),
- nombits = 9
- #endif
- };
- /// Seek directions, equivalent to SEEK_SET, SEEK_CUR, and SEEK_END.
- enum seekdir {
- beg,
- cur,
- end
- };
- /// I/O state bitmasks.
- enum iostate_bits {
- goodbit = 0,
- badbit = (1 << 0),
- eofbit = (1 << 1),
- failbit = (1 << 2),
- #ifndef DOXYGEN_SHOULD_SKIP_THIS
- nbadbits = 3,
- allbadbits = 0x7
- #endif
- };
-
- typedef uint32_t openmode; ///< Holds openmode_bits.
- typedef uint32_t iostate; ///< Holds iostate_bits for a file stream.
- typedef file_exception failure; ///< Thrown by fstream on errors.
-
- static const char c_DefaultDelimiters [16]; ///< Default word delimiters for stringstreams.
-public:
- inline ios_base (void) : m_State (goodbit), m_Exceptions (goodbit) {}
- inline iostate rdstate (void) const { return (m_State); }
- inline bool bad (void) const { return (rdstate() & badbit); }
- inline bool good (void) const { return (rdstate() == goodbit); }
- inline bool fail (void) const { return (rdstate() & (badbit | failbit)); }
- inline bool eof (void) const { return (rdstate() & eofbit); }
- inline bool operator! (void) const { return (fail()); }
- inline void clear (iostate v = goodbit) { m_State = v; }
- inline void setstate (iostate v) { m_State |= v; }
- inline iostate exceptions (void) const { return (m_Exceptions); }
- inline iostate exceptions (iostate v) { return (m_Exceptions = v); }
-protected:
- inline bool set_and_throw (iostate v) { setstate(v); return (exceptions() & v); }
-private:
- uint16_t m_State; ///< Open state, using ios::iostate_bits.
- uint16_t m_Exceptions; ///< Exception flags, using ios::iostate_bits.
-};
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uiosfunc.h b/media/libdrm/mobile2/src/util/ustl-1.0/uiosfunc.h
deleted file mode 100644
index fe26ed1..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uiosfunc.h
+++ /dev/null
@@ -1,103 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uiosfunc.h
-//
-
-#ifndef UIOSFUNC_H_730C16E316F7650E3A02E1C6611B789A
-#define UIOSFUNC_H_730C16E316F7650E3A02E1C6611B789A
-
-#include "sostream.h"
-
-namespace ustl {
-
-class ios : public ios_base {
-public:
- /// \class align uiosfunc.h ustl.h
- /// \ingroup StreamFunctors
- /// \brief Stream functor to allow inline align() calls.
- ///
- /// Example: os << ios::align(sizeof(uint16_t));
- ///
- class align {
- public:
- inline explicit align (size_t grain = c_DefaultAlignment) : m_Grain(grain) {}
- inline istream& apply (istream& is) const { is.align (m_Grain); return (is); }
- inline ostream& apply (ostream& os) const { os.align (m_Grain); return (os); }
- inline size_t stream_size (void) const { return (m_Grain - 1); }
- private:
- const size_t m_Grain;
- };
-
- /// \class talign uiosfunc.h ustl.h
- /// \ingroup StreamFunctors
- /// \brief Stream functor to allow type-based alignment.
- template <typename T>
- class talign : public align {
- public:
- inline explicit talign (void) : align (alignof (T())) {}
- };
-
- /// \class skip uiosfunc.h ustl.h
- /// \ingroup StreamFunctors
- /// \brief Stream functor to allow inline skip() calls.
- ///
- /// Example: os << ios::skip(sizeof(uint16_t));
- ///
- class skip {
- public:
- inline explicit skip (size_t nBytes) : m_nBytes(nBytes) {}
- inline istream& apply (istream& is) const { is.skip (m_nBytes); return (is); }
- inline ostream& apply (ostream& os) const { os.skip (m_nBytes); return (os); }
- inline size_t stream_size (void) const { return (m_nBytes); }
- private:
- const size_t m_nBytes;
- };
-
- /// \class width uiosfunc.h ustl.h
- /// \ingroup StreamFunctors
- /// \brief Stream functor to allow inline set_width() calls.
- ///
- /// Example: os << ios::width(15);
- ///
- class width {
- public:
- inline explicit width (size_t nBytes) : m_nBytes(nBytes) {}
- inline ostringstream& apply (ostringstream& os) const { os.set_width (m_nBytes); return (os); }
- private:
- const size_t m_nBytes;
- };
-
- /// \class base uiosfunc.h ustl.h
- /// \ingroup StreamFunctors
- /// \brief Stream functor to allow inline set_base() calls.
- ///
- /// Example: os << ios::base(15);
- ///
- class base {
- public:
- inline explicit base (size_t n) : m_Base(n) {}
- inline ostringstream& apply (ostringstream& os) const { os.set_base (m_Base); return (os); }
- private:
- const size_t m_Base;
- };
-};
-
-inline istream& operator>> (istream& is, const ios::skip& op) { return (op.apply (is)); }
-inline ostream& operator<< (ostream& os, const ios::skip& op) { return (op.apply (os)); }
-inline size_t stream_size_of (const ios::skip& op) { return (op.stream_size()); }
-inline istream& operator>> (istream& is, const ios::align& op) { return (op.apply (is)); }
-inline ostream& operator<< (ostream& os, const ios::align& op) { return (op.apply (os)); }
-inline size_t stream_size_of (const ios::align& op) { return (op.stream_size()); }
-inline ostringstream& operator<< (ostringstream& os, const ios::width& op) { return (op.apply (os)); }
-inline ostringstream& operator<< (ostringstream& os, const ios::base& op) { return (op.apply (os)); }
-
-} // namespace ustl
-
-CAST_STREAMABLE(ustl::ios::fmtflags, uint32_t)
-CAST_STREAMABLE(ustl::ios::seekdir, uint32_t)
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uiterator.h b/media/libdrm/mobile2/src/util/ustl-1.0/uiterator.h
deleted file mode 100644
index 48c0d2d..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uiterator.h
+++ /dev/null
@@ -1,268 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-/// \file uiterator.h
-/// \brief Contains various iterator adapters.
-//
-
-#ifndef UITERATOR_H_5BCA176C7214A30F2069E2614D2DC226
-#define UITERATOR_H_5BCA176C7214A30F2069E2614D2DC226
-
-#include "uassert.h"
-#include "utypes.h"
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-
-/// \struct iterator_traits uiterator.h ustl.h
-/// \brief Contains the type traits of \p Iterator
-///
-template <typename Iterator>
-struct iterator_traits {
- typedef typename Iterator::value_type value_type;
- typedef typename Iterator::difference_type difference_type;
- typedef typename Iterator::pointer pointer;
- typedef typename Iterator::reference reference;
-};
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-
-template <typename T>
-struct iterator_traits<T*> {
- typedef T value_type;
- typedef ptrdiff_t difference_type;
- typedef const T* const_pointer;
- typedef T* pointer;
- typedef T& reference;
-};
-
-template <typename T>
-struct iterator_traits<const T*> {
- typedef T value_type;
- typedef ptrdiff_t difference_type;
- typedef const T* const_pointer;
- typedef const T* pointer;
- typedef const T& reference;
-};
-
-template <>
-struct iterator_traits<void*> {
- typedef uint8_t value_type;
- typedef ptrdiff_t difference_type;
- typedef const void* const_pointer;
- typedef void* pointer;
- typedef value_type& reference;
-};
-
-template <>
-struct iterator_traits<const void*> {
- typedef uint8_t value_type;
- typedef ptrdiff_t difference_type;
- typedef const void* const_pointer;
- typedef const void* pointer;
- typedef const value_type& reference;
-};
-
-#endif
-
-//----------------------------------------------------------------------
-
-/// \class reverse_iterator uiterator.h ustl.h
-/// \ingroup IteratorAdaptors
-/// \brief Wraps \p Iterator to behave in an exactly opposite manner.
-///
-template <class Iterator>
-class reverse_iterator {
-public:
- typedef typename iterator_traits<Iterator>::value_type value_type;
- typedef typename iterator_traits<Iterator>::difference_type difference_type;
- typedef typename iterator_traits<Iterator>::pointer pointer;
- typedef typename iterator_traits<Iterator>::reference reference;
-public:
- reverse_iterator (void) : m_i() {}
- explicit reverse_iterator (Iterator iter) : m_i (iter) {}
- inline bool operator== (const reverse_iterator& iter) const { return (m_i == iter.m_i); }
- inline bool operator< (const reverse_iterator& iter) const { return (iter.m_i < m_i); }
- inline Iterator base (void) const { return (m_i); }
- inline reference operator* (void) const { Iterator prev (m_i); --prev; return (*prev); }
- inline pointer operator-> (void) const { return (&(operator*())); }
- inline reverse_iterator& operator++ (void) { -- m_i; return (*this); }
- inline reverse_iterator& operator-- (void) { ++ m_i; return (*this); }
- inline reverse_iterator operator++ (int) { reverse_iterator prev (*this); -- m_i; return (prev); }
- inline reverse_iterator operator-- (int) { reverse_iterator prev (*this); ++ m_i; return (prev); }
- inline reverse_iterator& operator+= (size_t n) { m_i -= n; return (*this); }
- inline reverse_iterator& operator-= (size_t n) { m_i += n; return (*this); }
- inline reverse_iterator operator+ (size_t n) const { return (reverse_iterator (m_i - n)); }
- inline reverse_iterator operator- (size_t n) const { return (reverse_iterator (m_i + n)); }
- inline reference operator[] (uoff_t n) const { return (*(*this + n)); }
- inline difference_type operator- (const reverse_iterator& i) const { return (distance (m_i, i.m_i)); }
-protected:
- Iterator m_i;
-};
-
-//----------------------------------------------------------------------
-
-/// \class insert_iterator uiterator.h ustl.h
-/// \ingroup IteratorAdaptors
-/// \brief Calls insert on bound container for each assignment.
-///
-template <class Container>
-class insert_iterator {
-public:
- typedef typename Container::value_type value_type;
- typedef typename Container::difference_type difference_type;
- typedef typename Container::pointer pointer;
- typedef typename Container::reference reference;
- typedef typename Container::iterator iterator;
-public:
- explicit insert_iterator (Container& ctr, iterator ip) : m_rCtr (ctr), m_ip (ip) {}
- inline insert_iterator& operator= (typename Container::const_reference v)
- { m_ip = m_rCtr.insert (m_ip, v); return (*this); }
- inline insert_iterator& operator* (void) { return (*this); }
- inline insert_iterator& operator++ (void) { ++ m_ip; return (*this); }
- inline insert_iterator operator++ (int) { insert_iterator prev (*this); ++ m_ip; return (*this); }
-protected:
- Container& m_rCtr;
- iterator m_ip;
-};
-
-/// Returns the insert_iterator for \p ctr.
-template <class Container>
-inline insert_iterator<Container> inserter (Container& ctr, typename Container::iterator ip)
-{
- return (insert_iterator<Container> (ctr, ip));
-}
-
-//----------------------------------------------------------------------
-
-/// \class back_insert_iterator uiterator.h ustl.h
-/// \ingroup IteratorAdaptors
-/// \brief Calls push_back on bound container for each assignment.
-///
-template <class Container>
-class back_insert_iterator {
-public:
- typedef typename Container::value_type value_type;
- typedef typename Container::difference_type difference_type;
- typedef typename Container::pointer pointer;
- typedef typename Container::reference reference;
-public:
- explicit back_insert_iterator (Container& ctr) : m_rCtr (ctr) {}
- inline back_insert_iterator& operator= (typename Container::const_reference v)
- { m_rCtr.push_back (v); return (*this); }
- inline back_insert_iterator& operator* (void) { return (*this); }
- inline back_insert_iterator& operator++ (void) { return (*this); }
- inline back_insert_iterator operator++ (int) { return (*this); }
-protected:
- Container& m_rCtr;
-};
-
-/// Returns the back_insert_iterator for \p ctr.
-template <class Container>
-inline back_insert_iterator<Container> back_inserter (Container& ctr)
-{
- return (back_insert_iterator<Container> (ctr));
-}
-
-//----------------------------------------------------------------------
-
-/// \class index_iterate uiterator.h ustl.h
-/// \ingroup IteratorAdaptors
-///
-/// \brief Allows iteration through an index container.
-///
-/// Converts an iterator into a container of uoff_t indexes to an
-/// iterator of iterators into another container.
-///
-template <typename RandomAccessIterator, typename IndexIterator>
-class index_iterate {
-public:
- typedef RandomAccessIterator value_type;
- typedef ptrdiff_t difference_type;
- typedef RandomAccessIterator* pointer;
- typedef RandomAccessIterator reference;
-public:
- index_iterate (void) : m_Base(), m_i() {}
- index_iterate (RandomAccessIterator ibase, IndexIterator iindex) : m_Base (ibase), m_i (iindex) {}
- inline bool operator== (const index_iterate& i) const { return (m_i == i.m_i); }
- inline bool operator< (const index_iterate& i) const { return (m_i < i.m_i); }
- inline bool operator== (const RandomAccessIterator& i) const { return (m_Base == i); }
- inline bool operator< (const RandomAccessIterator& i) const { return (m_Base < i); }
- inline IndexIterator base (void) const { return (m_i); }
- inline reference operator* (void) const { return (advance(m_Base, *m_i)); }
- inline pointer operator-> (void) const { return (&(operator*())); }
- inline index_iterate& operator++ (void) { ++ m_i; return (*this); }
- inline index_iterate& operator-- (void) { -- m_i; return (*this); }
- inline index_iterate operator++ (int) { index_iterate prev (*this); ++ m_i; return (prev); }
- inline index_iterate operator-- (int) { index_iterate prev (*this); -- m_i; return (prev); }
- inline index_iterate& operator+= (size_t n) { m_i += n; return (*this); }
- inline index_iterate& operator-= (size_t n) { m_i -= n; return (*this); }
- inline index_iterate operator+ (size_t n) const { return (index_iterate (m_Base, m_i + n)); }
- inline index_iterate operator- (size_t n) const { return (index_iterate (m_Base, m_i - n)); }
- inline reference operator[] (uoff_t n) const { return (*(*this + n)); }
- inline difference_type operator- (const index_iterate& i) const { return (distance (m_i, i.m_i)); }
-private:
- RandomAccessIterator m_Base;
- IndexIterator m_i;
-};
-
-/// Returns an index_iterate for \p ibase over \p iindex.
-template <typename RandomAccessIterator, typename IndexIterator>
-inline index_iterate<RandomAccessIterator, IndexIterator> index_iterator (RandomAccessIterator ibase, IndexIterator iindex)
-{
- return (index_iterate<RandomAccessIterator, IndexIterator> (ibase, iindex));
-}
-
-/// Converts the indexes in \p xc to iterators in \p ic of base \p ibase.
-template <typename IndexContainer, typename IteratorContainer>
-inline void indexv_to_iteratorv (typename IteratorContainer::value_type ibase, const IndexContainer& xc, IteratorContainer& ic)
-{
- ic.resize (xc.size());
- copy_n (index_iterator (ibase, xc.begin()), xc.size(), ic.begin());
-}
-
-//----------------------------------------------------------------------
-
-/// Converts the given const_iterator into an iterator.
-///
-template <typename Container>
-inline typename Container::iterator unconst (typename Container::const_iterator i, Container& ctr)
-{
- const Container& cctr = ctr;
- return (ctr.begin() + (i - cctr.begin()));
-}
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-
-#define IBYI(Iter1, Iter2, Ctr1, Ctr2) \
-template <typename Container1, typename Container2> \
-inline typename Container2::Iter2 ibyi (typename Container1::Iter1 idx, Ctr1& ctr1, Ctr2& ctr2) \
-{ \
- assert (ctr1.size() == ctr2.size()); \
- return (ctr2.begin() + (idx - ctr1.begin())); \
-}
-
-IBYI(const_iterator, const_iterator, const Container1, const Container2)
-IBYI(iterator, iterator, Container1, Container2)
-IBYI(const_iterator, iterator, const Container1, Container2)
-IBYI(iterator, const_iterator, Container1, const Container2)
-
-#else // DOXYGEN
-
-#error This declaration is for doxygen only; it is not compiled.
-
-/// Converts a const_iterator in one container into a const_iterator in another container.
-template <typename Container1, typename Container2>
-inline typename Container2::iterator ibyi (typename Container1::iterator idx, Container1& ctr1, Container2& ctr2) {}
-
-#endif // DOXYGEN
-
-//----------------------------------------------------------------------
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ulaalgo.h b/media/libdrm/mobile2/src/util/ustl-1.0/ulaalgo.h
deleted file mode 100644
index 1efc977..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ulaalgo.h
+++ /dev/null
@@ -1,223 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ulaalgo.h
-//
-
-#ifndef ULAALGO_H_2E403D182E83FB596AFB800E68B255A1
-#define ULAALGO_H_2E403D182E83FB596AFB800E68B255A1
-
-#include "umatrix.h"
-#include "simd.h"
-
-namespace ustl {
-
-/// \brief Creates an identity matrix in \p m
-/// \ingroup NumericAlgorithms
-template <size_t NX, size_t NY, typename T>
-void load_identity (matrix<NX,NY,T>& m)
-{
- fill_n (m.begin(), NX * NY, 0);
- for (typename matrix<NX,NY,T>::iterator i = m.begin(); i < m.end(); i += NX + 1)
- *i = 1;
-}
-
-/// \brief Multiplies two matrices
-/// \ingroup NumericAlgorithms
-template <size_t NX, size_t NY, typename T>
-matrix<NY,NY,T> operator* (const matrix<NX,NY,T>& m1, const matrix<NY,NX,T>& m2)
-{
- matrix<NY,NY,T> mr;
- for (uoff_t ry = 0; ry < NY; ++ ry) {
- for (uoff_t rx = 0; rx < NY; ++ rx) {
- T dpv (0);
- for (uoff_t x = 0; x < NX; ++ x)
- dpv += m1[ry][x] * m2[x][rx];
- mr[ry][rx] = dpv;
- }
- }
- return (mr);
-}
-
-/// \brief Transforms vector \p t with matrix \p m
-/// \ingroup NumericAlgorithms
-template <size_t NX, size_t NY, typename T>
-tuple<NX,T> operator* (const tuple<NY,T>& t, const matrix<NX,NY,T>& m)
-{
- tuple<NX,T> tr;
- for (uoff_t x = 0; x < NX; ++ x) {
- T dpv (0);
- for (uoff_t y = 0; y < NY; ++ y)
- dpv += t[y] * m[y][x];
- tr[x] = dpv;
- }
- return (tr);
-}
-
-/// \brief Transposes (exchanges rows and columns) matrix \p m.
-/// \ingroup NumericAlgorithms
-template <size_t N, typename T>
-void transpose (matrix<N,N,T>& m)
-{
- for (uoff_t x = 0; x < N; ++ x)
- for (uoff_t y = x; y < N; ++ y)
- swap (m[x][y], m[y][x]);
-}
-
-#if WANT_UNROLLED_COPY
-
-#if CPU_HAS_SSE
-
-#if linux // Non-linux gcc versions (BSD, Solaris) can't handle "x" constraint and provide no alternative.
-template <>
-inline void load_identity (matrix<4,4,float>& m)
-{
- asm (
- "movaps %4, %%xmm1 \n\t" // 1 0 0 0
- "movups %4, %0 \n\t" // 1 0 0 0
- "shufps $0xB1,%%xmm1,%%xmm1 \n\t" // 0 1 0 0
- "movups %%xmm1, %1 \n\t" // 0 1 0 0
- "shufps $0x4F,%4,%%xmm1 \n\t" // 0 0 1 0
- "shufps $0x1B,%4,%4 \n\t" // 0 0 0 1
- "movups %%xmm1, %2 \n\t" // 0 0 1 0
- "movups %4, %3" // 0 0 0 1
- : "=m"(m[0][0]), "=m"(m[1][0]), "=m"(m[2][0]), "=m"(m[3][0])
- : "x"(1.0f)
- : "xmm1"
- );
-}
-#endif
-
-inline void _sse_load_matrix (const float* m)
-{
- asm (
- "movups %0, %%xmm4 \n\t" // xmm4 = m[1 2 3 4]
- "movups %1, %%xmm5 \n\t" // xmm5 = m[1 2 3 4]
- "movups %2, %%xmm6 \n\t" // xmm6 = m[1 2 3 4]
- "movups %3, %%xmm7" // xmm7 = m[1 2 3 4]
- : : "m"(m[0]), "m"(m[4]), "m"(m[8]), "m"(m[12])
- : "xmm4", "xmm5", "xmm6", "xmm7"
- );
-}
-
-inline void _sse_transform_to_vector (float* result)
-{
- asm (
- "movaps %%xmm0, %%xmm1 \n\t" // xmm1 = t[0 1 2 3]
- "movaps %%xmm0, %%xmm2 \n\t" // xmm1 = t[0 1 2 3]
- "movaps %%xmm0, %%xmm3 \n\t" // xmm1 = t[0 1 2 3]
- "shufps $0x00, %%xmm0, %%xmm0 \n\t" // xmm0 = t[0 0 0 0]
- "shufps $0x66, %%xmm1, %%xmm1 \n\t" // xmm1 = t[1 1 1 1]
- "shufps $0xAA, %%xmm2, %%xmm2 \n\t" // xmm2 = t[2 2 2 2]
- "shufps $0xFF, %%xmm3, %%xmm3 \n\t" // xmm3 = t[3 3 3 3]
- "mulps %%xmm4, %%xmm0 \n\t" // xmm0 = t[0 0 0 0] * m[0 1 2 3]
- "mulps %%xmm5, %%xmm1 \n\t" // xmm1 = t[1 1 1 1] * m[0 1 2 3]
- "addps %%xmm1, %%xmm0 \n\t" // xmm0 = xmm0 + xmm1
- "mulps %%xmm6, %%xmm2 \n\t" // xmm2 = t[2 2 2 2] * m[0 1 2 3]
- "mulps %%xmm7, %%xmm3 \n\t" // xmm3 = t[3 3 3 3] * m[0 1 2 3]
- "addps %%xmm3, %%xmm2 \n\t" // xmm2 = xmm2 + xmm3
- "addps %%xmm2, %%xmm0 \n\t" // xmm0 = result
- "movups %%xmm0, %0"
- : "=m"(result[0]) :
- : "xmm0", "xmm1", "xmm2", "xmm3", "xmm4", "xmm5", "xmm6", "xmm7"
- );
-}
-
-template <>
-tuple<4,float> operator* (const tuple<4,float>& t, const matrix<4,4,float>& m)
-{
- tuple<4,float> result;
- _sse_load_matrix (m.begin());
- asm ("movups %0, %%xmm0" : : "m"(t[0]) : "xmm0");
- _sse_transform_to_vector (result.begin());
- return (result);
-}
-
-template <>
-matrix<4,4,float> operator* (const matrix<4,4,float>& m1, const matrix<4,4,float>& m2)
-{
- matrix<4,4,float> result;
- _sse_load_matrix (m2.begin());
- for (uoff_t r = 0; r < 4; ++ r) {
- asm ("movups %0, %%xmm0" : : "m"(m1[r][0]) : "xmm0");
- _sse_transform_to_vector (result[r]);
- }
- return (result);
-}
-
-#elif CPU_HAS_3DNOW
-
-/// Specialization for 4-component vector transform, the slow part of 3D graphics.
-template <>
-tuple<4,float> operator* (const tuple<4,float>& t, const matrix<4,4,float>& m)
-{
- tuple<4,float> result;
- // This is taken from "AMD Athlon Code Optimization Guide" from AMD. 18 cycles!
- // If you are writing a 3D engine, you may want to copy it instead of calling it
- // because of the femms instruction at the end, which takes 2 cycles.
- asm (
- "movq %2, %%mm0 \n\t" // y | x
- "movq %3, %%mm1 \n\t" // w | z
- "movq %%mm0, %%mm2 \n\t" // y | x
- "movq %4, %%mm3 \n\t" // m[0][1] | m[0][0]
- "punpckldq %%mm0, %%mm0 \n\t" // x | x
- "movq %6, %%mm4 \n\t" // m[1][1] | m[1][0]
- "pfmul %%mm0, %%mm3 \n\t" // x*m[0][1] | x*m[0][0]
- "punpckhdq %%mm2, %%mm2 \n\t" // y | y
- "pfmul %%mm2, %%mm4 \n\t" // y*m[1][1] | y*m[1][0]
- "movq %5, %%mm5 \n\t" // m[0][3] | m[0][2]
- "movq %7, %%mm7 \n\t" // m[1][3] | m[1][2]
- "movq %%mm1, %%mm6 \n\t" // w | z
- "pfmul %%mm0, %%mm5 \n\t" // x*m[0][3] | v0>x*m[0][2]
- "movq %8, %%mm0 \n\t" // m[2][1] | m[2][0]
- "punpckldq %%mm1, %%mm1 \n\t" // z | z
- "pfmul %%mm2, %%mm7 \n\t" // y*m[1][3] | y*m[1][2]
- "movq %9, %%mm2 \n\t" // m[2][3] | m[2][2]
- "pfmul %%mm1, %%mm0 \n\t" // z*m[2][1] | z*m[2][0]
- "pfadd %%mm4, %%mm3 \n\t" // x*m[0][1]+y*m[1][1] | x*m[0][0]+y*m[1][0]
- "movq %10, %%mm4 \n\t" // m[3][1] | m[3][0]
- "pfmul %%mm1, %%mm2 \n\t" // z*m[2][3] | z*m[2][2]
- "pfadd %%mm7, %%mm5 \n\t" // x*m[0][3]+y*m[1][3] | x*m[0][2]+y*m[1][2]
- "movq %11, %%mm1 \n\t" // m[3][3] | m[3][2]
- "punpckhdq %%mm6, %%mm6 \n\t" // w | w
- "pfadd %%mm0, %%mm3 \n\t" // x*m[0][1]+y*m[1][1]+z*m[2][1] | x*m[0][0]+y*m[1][0]+z*m[2][0]
- "pfmul %%mm6, %%mm4 \n\t" // w*m[3][1] | w*m[3][0]
- "pfmul %%mm6, %%mm1 \n\t" // w*m[3][3] | w*m[3][2]
- "pfadd %%mm2, %%mm5 \n\t" // x*m[0][3]+y*m[1][3]+z*m[2][3] | x*m[0][2]+y*m[1][2]+z*m[2][2]
- "pfadd %%mm4, %%mm3 \n\t" // x*m[0][1]+y*m[1][1]+z*m[2][1]+w*m[3][1] | x*m[0][0]+y*m[1][0]+z*m[2][0]+w*m[3][0]
- "movq %%mm3, %0 \n\t" // store result->y | result->x
- "pfadd %%mm1, %%mm5 \n\t" // x*m[0][3]+y*m[1][3]+z*m[2][3]+w*m[3][3] | x*m[0][2]+y*m[1][2]+z*m[2][2]+w*m[3][2]
- "movq %%mm5, %1" // store result->w | result->z
- : "=m"(result[0]), "=m"(result[2])
- : "m"(t[0]), "m"(t[2]),
- "m"(m[0][0]), "m"(m[0][2]),
- "m"(m[1][0]), "m"(m[1][2]),
- "m"(m[2][0]), "m"(m[2][2]),
- "m"(m[3][0]), "m"(m[3][2])
- : "mm0","mm1","mm2","mm3","mm4","mm5","mm6","mm7"
- );
- simd::reset_mmx();
- return (result);
-}
-
-#else // If no processor extensions, just unroll the multiplication
-
-/// Specialization for 4-component vector transform, the slow part of 3D graphics.
-template <>
-tuple<4,float> operator* (const tuple<4,float>& t, const matrix<4,4,float>& m)
-{
- tuple<4,float> tr;
- for (uoff_t i = 0; i < 4; ++ i)
- tr[i] = t[0] * m[0][i] + t[1] * m[1][i] + t[2] * m[2][i] + t[3] * m[3][i];
- return (tr);
-}
-
-#endif // CPU_HAS_3DNOW
-#endif // WANT_UNROLLED_COPY
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ulimits.h b/media/libdrm/mobile2/src/util/ustl-1.0/ulimits.h
deleted file mode 100644
index 85f1db1..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ulimits.h
+++ /dev/null
@@ -1,108 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ulimits.h
-//
-
-#ifndef ULIMITS_H_1C2192EA3821E0811BBAF86B0F048364
-#define ULIMITS_H_1C2192EA3821E0811BBAF86B0F048364
-
-#include "utypes.h"
-#include <stdint.h>
-
-namespace ustl {
-
-// Android
-#ifndef UINTPTR_MAX
-#define UINTPTR_MAX UINT32_MAX
-#endif
-
-#ifndef UINT32_MAX
-#define UINT32_MAX (0xffffffff)
-#endif
-
-/// \class numeric_limits ulimits.h ustl.h
-/// \brief Defines numeric limits for a type.
-///
-template <typename T>
-struct numeric_limits {
- /// Returns the minimum value for type T.
- static inline T min (void) { return (T(0)); }
- /// Returns the minimum value for type T.
- static inline T max (void) { return (T(0)); }
- static const bool is_signed = false; ///< True if the type is signed.
- static const bool is_integer = false; ///< True if stores an exact value.
- static const bool is_integral = false; ///< True if fixed size and cast-copyable.
-};
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-
-template <typename T>
-struct numeric_limits<T*> {
- static inline T* min (void) { return (NULL); }
- static inline T* max (void) { return (UINTPTR_MAX); }
- static const bool is_signed = false;
- static const bool is_integer = true;
- static const bool is_integral = true;
-};
-
-#define _NUMERIC_LIMITS(type, minVal, maxVal, bSigned, bInteger, bIntegral) \
-template <> \
-struct numeric_limits<type> { \
- static inline type min (void) { return (minVal); } \
- static inline type max (void) { return (maxVal); } \
- static const bool is_signed = bSigned; \
- static const bool is_integer = bInteger; \
- static const bool is_integral = bIntegral; \
-}
-
-//--------------------------------------------------------------------------------------
-// type min max signed integer integral
-//--------------------------------------------------------------------------------------
-_NUMERIC_LIMITS (bool, false, true, false, true, true);
-_NUMERIC_LIMITS (char, SCHAR_MIN, SCHAR_MAX, true, true, true);
-_NUMERIC_LIMITS (int, INT_MIN, INT_MAX, true, true, true);
-_NUMERIC_LIMITS (short, SHRT_MIN, SHRT_MAX, true, true, true);
-_NUMERIC_LIMITS (long, LONG_MIN, LONG_MAX, true, true, true);
-#if HAVE_THREE_CHAR_TYPES
-_NUMERIC_LIMITS (signed char, SCHAR_MIN, SCHAR_MAX, true, true, true);
-#endif
-_NUMERIC_LIMITS (unsigned char, 0, UCHAR_MAX, false, true, true);
-_NUMERIC_LIMITS (unsigned int, 0, UINT_MAX, false, true, true);
-_NUMERIC_LIMITS (unsigned short,0, USHRT_MAX, false, true, true);
-_NUMERIC_LIMITS (unsigned long, 0, ULONG_MAX, false, true, true);
-_NUMERIC_LIMITS (wchar_t, 0, WCHAR_MAX, false, true, true);
-_NUMERIC_LIMITS (float, FLT_MIN, FLT_MAX, true, false, true);
-_NUMERIC_LIMITS (double, DBL_MIN, DBL_MAX, true, false, true);
-_NUMERIC_LIMITS (long double, LDBL_MIN, LDBL_MAX, true, false, true);
-#ifdef HAVE_LONG_LONG
-_NUMERIC_LIMITS (long long, LLONG_MIN, LLONG_MAX, true, true, true);
-_NUMERIC_LIMITS (unsigned long long, 0, ULLONG_MAX, false, true, true);
-#endif
-//--------------------------------------------------------------------------------------
-
-#endif // DOXYGEN_SHOULD_SKIP_THIS
-
-/// Macro for defining numeric_limits specializations
-#define NUMERIC_LIMITS(type, minVal, maxVal, bSigned, bInteger, bIntegral) \
-namespace ustl { _NUMERIC_LIMITS (type, minVal, maxVal, bSigned, bInteger, bIntegral); }
-
-/// Returns the recommended stream alignment for type \p T. Override with ALIGNOF.
-template <typename T>
-inline size_t alignof (const T&)
-{
- if (numeric_limits<T>::is_integral)
- return (__alignof__(T));
- return (4);
-}
-
-#define ALIGNOF(type,grain) \
-namespace ustl { \
- template <> inline size_t alignof (const type&) { return (grain); } }
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ulist.h b/media/libdrm/mobile2/src/util/ustl-1.0/ulist.h
deleted file mode 100644
index 842bbde..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ulist.h
+++ /dev/null
@@ -1,78 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ulist.h
-//
-
-#ifndef ULIST_H_54E3B510498982C87A0A1E1932E6729D
-#define ULIST_H_54E3B510498982C87A0A1E1932E6729D
-
-#include "uvector.h"
-#include "uctralgo.h"
-
-namespace ustl {
-
-/// \class list ulist.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief Linked list, defined as an alias to \ref vector.
-///
-template <typename T>
-class list : public vector<T> {
-public:
- typedef typename vector<T>::size_type size_type;
- typedef typename vector<T>::iterator iterator;
- typedef typename vector<T>::const_iterator const_iterator;
- typedef typename vector<T>::reference reference;
- typedef typename vector<T>::const_reference const_reference;
-public:
- inline list (void) : vector<T> () {}
- inline explicit list (size_type n) : vector<T> (n) {}
- inline list (size_type n, const T& v) : vector<T> (n, v) {}
- inline list (const list<T>& v) : vector<T> (v) {}
- inline list (const_iterator i1, const_iterator i2) : vector<T> (i1, i2) {}
- inline size_type size (void) const { return (vector<T>::size()); }
- inline iterator begin (void) { return (vector<T>::begin()); }
- inline const_iterator begin (void) const { return (vector<T>::begin()); }
- inline iterator end (void) { return (vector<T>::end()); }
- inline const_iterator end (void) const { return (vector<T>::end()); }
- inline void push_front (const T& v) { insert (begin(), v); }
- inline void pop_front (void) { erase (begin()); }
- inline const_reference front (void) const { return (*begin()); }
- inline reference front (void) { return (*begin()); }
- inline void remove (const T& v) { ::ustl::remove (*this, v); }
- inline void unique (void) { ::ustl::unique (*this); }
- inline void sort (void) { ::ustl::sort (*this); }
- void merge (list<T>& l);
- void splice (iterator ip, list<T>& l, iterator first = NULL, iterator last = NULL);
-};
-
-/// Merges the contents with \p l. Assumes both lists are sorted.
-template <typename T>
-void list<T>::merge (list& l)
-{
- list<T>::resize (size() + l.size());
- iterator me = merge (begin(), end(), l.begin(), l.end(), begin());
- list<T>::resize (distance (begin(), me));
-}
-
-/// Moves the range [first, last) from \p l to this list at \p ip.
-template <typename T>
-void list<T>::splice (iterator ip, list<T>& l, iterator first, iterator last)
-{
- if (!first)
- first = l.begin();
- if (!last)
- last = l.end();
- insert (ip, first, last);
- l.erase (first, last);
-}
-
-#define deque list ///< list has all the functionality provided by deque
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/umap.h b/media/libdrm/mobile2/src/util/ustl-1.0/umap.h
deleted file mode 100644
index 938c507..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/umap.h
+++ /dev/null
@@ -1,165 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// umap.h
-//
-
-#ifndef UMAP_H_45643F516E02A87A3DCEA5024052A6F5
-#define UMAP_H_45643F516E02A87A3DCEA5024052A6F5
-
-#include "uassert.h"
-#include "ufunction.h"
-#include "uvector.h"
-
-namespace ustl {
-
-/// \class map umap.h ustl.h
-/// \ingroup AssociativeContainers
-///
-/// \brief A sorted associative container of pair<K,V>
-///
-template <typename K, typename V>
-class map : public vector<pair<K,V> > {
-public:
- typedef K key_type;
- typedef V data_type;
- typedef const K& const_key_ref;
- typedef const V& const_data_ref;
- typedef const map<K,V>& rcself_t;
- typedef vector<pair<K,V> > base_class;
- typedef typename base_class::value_type value_type;
- typedef typename base_class::size_type size_type;
- typedef typename base_class::pointer pointer;
- typedef typename base_class::const_pointer const_pointer;
- typedef typename base_class::reference reference;
- typedef typename base_class::const_reference const_reference;
- typedef typename base_class::const_iterator const_iterator;
- typedef typename base_class::iterator iterator;
- typedef typename base_class::reverse_iterator reverse_iterator;
- typedef typename base_class::const_reverse_iterator const_reverse_iterator;
- typedef pair<const_iterator,const_iterator> const_range_t;
- typedef pair<iterator,iterator> range_t;
-public:
- inline map (void) : vector<pair<K,V> > () {}
- explicit inline map (size_type n) : vector<pair<K,V> > (n) {}
- inline map (rcself_t v) : vector<pair<K,V> > (v) {}
- inline map (const_iterator i1, const_iterator i2) : vector<pair<K,V> >() { insert (i1, i2); }
- inline rcself_t operator= (rcself_t v) { base_class::operator= (v); return (*this); }
- inline const_data_ref operator[] (const_key_ref i) const;
- data_type& operator[] (const_key_ref i);
- inline size_type size (void) const { return (base_class::size()); }
- inline iterator begin (void) { return (base_class::begin()); }
- inline const_iterator begin (void) const { return (base_class::begin()); }
- inline iterator end (void) { return (base_class::end()); }
- inline const_iterator end (void) const { return (base_class::end()); }
- inline void assign (const_iterator i1, const_iterator i2) { clear(); insert (i1, i2); }
- inline void push_back (const_reference v) { insert (v); }
- inline const_iterator find (const_key_ref k) const;
- inline iterator find (const_key_ref k) { return (const_cast<iterator> (const_cast<rcself_t>(*this).find (k))); }
- inline const_iterator find_data (const_data_ref v, const_iterator first = NULL, const_iterator last = NULL) const;
- inline iterator find_data (const_data_ref v, iterator first = NULL, iterator last = NULL);
- iterator insert (const_reference v);
- void insert (const_iterator i1, const_iterator i2);
- inline void erase (const_key_ref k);
- inline iterator erase (iterator ep) { return (base_class::erase (ep)); }
- inline iterator erase (iterator ep1, iterator ep2) { return (base_class::erase (ep1, ep2)); }
- inline void clear (void) { base_class::clear(); }
-private:
- const_iterator lower_bound (const_key_ref k) const;
- inline iterator lower_bound (const_key_ref k) { return (const_cast<iterator>(const_cast<rcself_t>(*this).lower_bound (k))); }
-};
-
-template <typename K, typename V>
-typename map<K,V>::const_iterator map<K,V>::lower_bound (const_key_ref k) const
-{
- const_iterator first (begin()), last (end());
- while (first != last) {
- const_iterator mid = advance (first, distance (first,last) / 2);
- if (mid->first < k)
- first = advance (mid, 1);
- else
- last = mid;
- }
- return (first);
-}
-
-/// Returns the pair<K,V> where K = \p k.
-template <typename K, typename V>
-inline typename map<K,V>::const_iterator map<K,V>::find (const_key_ref k) const
-{
- const_iterator i = lower_bound (k);
- return ((i < end() && k < i->first) ? end() : i);
-}
-
-/// Returns the pair<K,V> where V = \p v, occuring in range [first,last).
-template <typename K, typename V>
-inline typename map<K,V>::const_iterator map<K,V>::find_data (const_data_ref v, const_iterator first, const_iterator last) const
-{
- if (!first) first = begin();
- if (!last) last = end();
- for (; first != last && first->second != v; ++first);
- return (first);
-}
-
-/// Returns the pair<K,V> where V = \p v, occuring in range [first,last).
-template <typename K, typename V>
-inline typename map<K,V>::iterator map<K,V>::find_data (const_data_ref v, iterator first, iterator last)
-{
- return (const_cast<iterator> (find_data (v, const_cast<const_iterator>(first), const_cast<const_iterator>(last))));
-}
-
-/// Returns data associated with key \p k.
-template <typename K, typename V>
-inline const typename map<K,V>::data_type& map<K,V>::operator[] (const_key_ref k) const
-{
- assert (find(k) != end() && "operator[] const can not insert non-existent keys");
- return (find(k)->second);
-}
-
-/// Returns data associated with key \p k.
-template <typename K, typename V>
-typename map<K,V>::data_type& map<K,V>::operator[] (const_key_ref k)
-{
- iterator ip = lower_bound (k);
- if (ip == end() || k < ip->first)
- ip = base_class::insert (ip, make_pair (k, V()));
- return (ip->second);
-}
-
-/// Inserts the pair into the container.
-template <typename K, typename V>
-typename map<K,V>::iterator map<K,V>::insert (const_reference v)
-{
- iterator ip = lower_bound (v.first);
- if (ip == end() || v.first < ip->first)
- ip = base_class::insert (ip, v);
- else
- *ip = v;
- return (ip);
-}
-
-/// Inserts elements from range [i1,i2) into the container.
-template <typename K, typename V>
-void map<K,V>::insert (const_iterator i1, const_iterator i2)
-{
- assert (i1 <= i2);
- reserve (size() + distance (i1, i2));
- for (; i1 != i2; ++i1)
- insert (*i1);
-}
-
-/// Erases the element with key value \p k.
-template <typename K, typename V>
-inline void map<K,V>::erase (const_key_ref k)
-{
- iterator ip = find (k);
- if (ip != end())
- erase (ip);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/umatrix.h b/media/libdrm/mobile2/src/util/ustl-1.0/umatrix.h
deleted file mode 100644
index e6810f1..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/umatrix.h
+++ /dev/null
@@ -1,80 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// umatrix.h
-//
-
-#ifndef UMATRIX_H_740EBFEF554E833645E0FD72419A8185
-#define UMATRIX_H_740EBFEF554E833645E0FD72419A8185
-
-#include "utuple.h"
-
-namespace ustl {
-
-/// \class matrix umatrix.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief A two-dimensional array of NX*NY elements of type T.
-///
-template <size_t NX, size_t NY, typename T>
-class matrix : public tuple<NX*NY,T> {
-public:
- typedef tuple<NX,T> row_type;
- typedef tuple<NY,T> column_type;
- typedef tuple<NX*NY,T> tuple_type;
- typedef typename tuple_type::value_type value_type;
- typedef typename tuple_type::size_type size_type;
- typedef typename tuple_type::pointer pointer;
- typedef typename tuple_type::const_pointer const_pointer;
- typedef typename tuple_type::reference reference;
- typedef typename tuple_type::const_reference const_reference;
- typedef typename tuple_type::iterator iterator;
- typedef typename tuple_type::const_iterator const_iterator;
- typedef typename tuple_type::range_t range_t;
- typedef typename tuple_type::const_range_t const_range_t;
- typedef typename tuple_type::reverse_iterator reverse_iterator;
- typedef typename tuple_type::const_reverse_iterator const_reverse_iterator;
-public:
- inline matrix (void) { fill_n (matrix::begin(), NX*NY, T()); }
- inline size_type columns (void) const { return (NX); }
- inline size_type rows (void) const { return (NY); }
- inline const_iterator at (size_type i) const { return (matrix::begin() + i * NX); }
- inline iterator at (size_type i) { return (matrix::begin() + i * NX); }
- inline const_iterator operator[] (size_type i) const { return (at (i)); }
- inline iterator operator[] (size_type i) { return (at (i)); }
- inline row_type row (size_type r) const { return (row_type (at (r))); }
- inline column_type column (size_type c) const;
- template <typename T2>
- inline const matrix& operator= (const matrix<NX,NY,T2>& src) { tuple_type::operator= (src); return (*this); }
- inline const matrix& operator= (const matrix<NX,NY,T>& src) { tuple_type::operator= (src); return (*this); }
- inline const matrix& operator+= (const_reference v) { tuple_type::operator+= (v); return (*this); }
- inline const matrix& operator-= (const_reference v) { tuple_type::operator-= (v); return (*this); }
- inline const matrix& operator*= (const_reference v) { tuple_type::operator*= (v); return (*this); }
- inline const matrix& operator/= (const_reference v) { tuple_type::operator/= (v); return (*this); }
- inline const matrix operator+ (const_reference v) const
- { matrix result (*this); result += v; return (result); }
- inline const matrix operator- (const_reference v) const
- { matrix result (*this); result -= v; return (result); }
- inline const matrix operator* (const_reference v) const
- { matrix result (*this); result *= v; return (result); }
- inline const matrix operator/ (const_reference v) const
- { matrix result (*this); result /= v; return (result); }
-};
-
-template <size_t NX, size_t NY, typename T>
-inline typename matrix<NX,NY,T>::column_type matrix<NX,NY,T>::column (size_type c) const
-{
- column_type result;
- const_iterator src (matrix::begin() + c);
- iterator dest (result.begin());
- for (uoff_t i = 0; i < NY; ++ i, ++ dest, src += NX)
- *dest = *src;
- return (result);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/umemory.h b/media/libdrm/mobile2/src/util/ustl-1.0/umemory.h
deleted file mode 100644
index 75a9005..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/umemory.h
+++ /dev/null
@@ -1,199 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// umemory.h
-//
-
-#ifndef UMEMORY_H_4AB5B0DB5BF09140541409CC47BCD17A
-#define UMEMORY_H_4AB5B0DB5BF09140541409CC47BCD17A
-
-#include "unew.h"
-#ifdef HAVE_ALLOCA_H
- #include <alloca.h>
-#else
- #include <stdlib.h>
-#endif
-#include "upair.h"
-#include "uiterator.h"
-#include "ulimits.h"
-
-namespace ustl {
-
-/// \class auto_ptr umemory.h ustl.h
-/// \ingroup MemoryManagement
-///
-/// \brief A smart pointer.
-///
-/// Calls delete in the destructor; assignment transfers ownership.
-/// This class does not work with void pointers due to the absence
-/// of the required dereference operator.
-///
-template <typename T>
-class auto_ptr {
-public:
- typedef T value_type;
- typedef T* pointer;
- typedef T& reference;
-public:
- /// Takes ownership of \p p.
- inline explicit auto_ptr (pointer p = NULL) : m_p (p) {}
- /// Takes ownership of pointer in \p p. \p p relinquishes ownership.
- inline auto_ptr (auto_ptr<T>& p) : m_p (p.release()) {}
- /// Deletes the owned pointer.
- inline ~auto_ptr (void) { delete m_p; }
- /// Returns the pointer without relinquishing ownership.
- inline pointer get (void) const { return (m_p); }
- /// Returns the pointer and gives up ownership.
- inline pointer release (void) { pointer rv (m_p); m_p = NULL; return (rv); }
- /// Deletes the pointer and sets it equal to \p p.
- inline void reset (pointer p) { if (p != m_p) { delete m_p; m_p = p; } }
- /// Takes ownership of \p p.
- inline auto_ptr<T>& operator= (pointer p) { reset (p); return (*this); }
- /// Takes ownership of pointer in \p p. \p p relinquishes ownership.
- inline auto_ptr<T>& operator= (auto_ptr<T>& p) { reset (p.release()); return (*this); }
- inline reference operator* (void) const { return (*m_p); }
- inline pointer operator-> (void) const { return (m_p); }
- inline bool operator== (const pointer p) const { return (m_p == p); }
- inline bool operator== (const auto_ptr<T>& p) const { return (m_p == p.m_p); }
- inline bool operator< (const auto_ptr<T>& p) const { return (p.m_p < m_p); }
-private:
- pointer m_p;
-};
-
-/// Calls the placement new on \p p.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename T>
-inline void construct (T* p)
-{
- new (p) T;
-}
-
-/// Calls the placement new on \p p.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename ForwardIterator>
-inline void construct (ForwardIterator first, ForwardIterator last)
-{
- typedef typename iterator_traits<ForwardIterator>::value_type value_type;
- if (!numeric_limits<value_type>::is_integral) {
- while (first < last) {
- construct (&*first);
- ++ first;
- }
- }
-}
-
-/// Calls the placement new on \p p.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename T>
-inline void construct (T* p, const T& value)
-{
- new (p) T (value);
-}
-
-/// Calls the destructor of \p p without calling delete.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename T>
-inline void destroy (T* p) throw()
-{
- p->~T();
-}
-
-/// Calls the destructor on elements in range [first, last) without calling delete.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename ForwardIterator>
-inline void destroy (ForwardIterator first, ForwardIterator last) throw()
-{
- typedef typename iterator_traits<ForwardIterator>::value_type value_type;
- if (!numeric_limits<value_type>::is_integral)
- for (; first < last; ++ first)
- destroy (&*first);
-}
-
-/// Casts \p p to the type of the second pointer argument.
-template <typename T> inline T* cast_to_type (void* p, const T*) { return ((T*) p); }
-
-/// \brief Creates a temporary buffer pair from \p p and \p n
-/// This is intended to be used with alloca to create temporary buffers.
-/// The size in the returned pair is set to 0 if the allocation is unsuccessful.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename T>
-inline pair<T*, ptrdiff_t> make_temporary_buffer (void* p, size_t n, const T* ptype)
-{
- return (make_pair (cast_to_type(p,ptype), ptrdiff_t(p ? n : 0)));
-}
-
-#ifdef HAVE_ALLOCA_H
- /// \brief Allocates a temporary buffer, if possible.
- /// \ingroup RawStorageAlgorithms
- #define get_temporary_buffer(size, ptype) make_temporary_buffer (alloca(size_of_elements(size, ptype)), size, ptype)
- #define return_temporary_buffer(p)
-#else
- #define get_temporary_buffer(size, ptype) make_temporary_buffer (malloc(size_of_elements(size, ptype)), size, ptype)
- #define return_temporary_buffer(p) if (p) free (p), p = NULL
-#endif
-
-/// Copies [first, last) into result by calling copy constructors in result.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename InputIterator, typename ForwardIterator>
-ForwardIterator uninitialized_copy (InputIterator first, InputIterator last, ForwardIterator result)
-{
- while (first < last) {
- construct (&*result, *first);
- ++ result;
- ++ first;
- }
- return (result);
-}
-
-/// Copies [first, first + n) into result by calling copy constructors in result.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename InputIterator, typename ForwardIterator>
-ForwardIterator uninitialized_copy_n (InputIterator first, size_t n, ForwardIterator result)
-{
- while (n--) {
- construct (&*result, *first);
- ++ result;
- ++ first;
- }
- return (result);
-}
-
-/// Calls construct on all elements in [first, last) with value \p v.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename ForwardIterator, typename T>
-void uninitialized_fill (ForwardIterator first, ForwardIterator last, const T& v)
-{
- while (first < last) {
- construct (&*first, v);
- ++ first;
- }
-}
-
-/// Calls construct on all elements in [first, first + n) with value \p v.
-/// \ingroup RawStorageAlgorithms
-///
-template <typename ForwardIterator, typename T>
-ForwardIterator uninitialized_fill_n (ForwardIterator first, size_t n, const T& v)
-{
- while (n--) {
- construct (&*first, v);
- ++ first;
- }
- return (first);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/umultimap.h b/media/libdrm/mobile2/src/util/ustl-1.0/umultimap.h
deleted file mode 100644
index dd6ca48..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/umultimap.h
+++ /dev/null
@@ -1,121 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// umultimap.h
-//
-
-#ifndef UMULTIMAP_H_45743F516E02A87A3FCEA5024052A6F5
-#define UMULTIMAP_H_45743F516E02A87A3FCEA5024052A6F5
-
-#include "uassert.h"
-#include "ufunction.h"
-#include "uvector.h"
-
-namespace ustl {
-
-/// \class multimap umultimap.h ustl.h
-/// \ingroup AssociativeContainers
-///
-/// \brief A sorted associative container that may container multiple entries for each key.
-///
-template <typename K, typename V>
-class multimap : public vector<pair<K,V> > {
-public:
- typedef K key_type;
- typedef V data_type;
- typedef const K& const_key_ref;
- typedef const V& const_data_ref;
- typedef const multimap<K,V>& rcself_t;
- typedef vector<pair<K,V> > base_class;
- typedef typename base_class::value_type value_type;
- typedef typename base_class::size_type size_type;
- typedef typename base_class::pointer pointer;
- typedef typename base_class::const_pointer const_pointer;
- typedef typename base_class::reference reference;
- typedef typename base_class::const_reference const_reference;
- typedef typename base_class::const_iterator const_iterator;
- typedef typename base_class::iterator iterator;
- typedef typename base_class::reverse_iterator reverse_iterator;
- typedef typename base_class::const_reverse_iterator const_reverse_iterator;
- typedef pair<const_iterator,const_iterator> const_range_t;
- typedef pair<iterator,iterator> range_t;
-public:
- inline multimap (void) : vector<pair<K,V> > () {}
- explicit inline multimap (size_type n) : vector<pair<K,V> > (n) {}
- inline multimap (rcself_t v) : vector<pair<K,V> > (v) {}
- inline multimap (const_iterator i1, const_iterator i2) : vector<pair<K,V> > () { insert (i1, i2); }
- inline rcself_t operator= (rcself_t v) { base_class::operator= (v); return (*this); }
- inline size_type size (void) const { return (base_class::size()); }
- inline iterator begin (void) { return (base_class::begin()); }
- inline const_iterator begin (void) const { return (base_class::begin()); }
- inline iterator end (void) { return (base_class::end()); }
- inline const_iterator end (void) const { return (base_class::end()); }
- inline void assign (const_iterator i1, const_iterator i2) { clear(); insert (i1, i2); }
- inline size_type count (const_key_ref k) const { return (upper_bound(k) - lower_bound(k)); }
- inline void push_back (const_reference v) { insert (v); }
- inline const_range_t equal_range (const_key_ref k) const { return (make_pair (lower_bound(k), upper_bound(k))); }
- inline range_t equal_range (const_key_ref k) { return (make_pair (const_cast<iterator>(lower_bound(k)), const_cast<iterator>(upper_bound(k)))); }
- const_iterator lower_bound (const_key_ref k) const;
- const_iterator upper_bound (const_key_ref k) const;
- inline iterator insert (const_reference v);
- void insert (const_iterator i1, const_iterator i2);
- inline void erase (const_key_ref k) { erase (const_cast<iterator>(lower_bound(k)), const_cast<iterator>(upper_bound(k))); }
- inline iterator erase (iterator ep) { return (base_class::erase (ep)); }
- inline iterator erase (iterator ep1, iterator ep2) { return (base_class::erase (ep1, ep2)); }
- inline void clear (void) { base_class::clear(); }
-};
-
-/// Returns an iterator to the first element with key value \p k.
-template <typename K, typename V>
-typename multimap<K,V>::const_iterator multimap<K,V>::lower_bound (const_key_ref k) const
-{
- const_iterator first (begin()), last (end());
- while (first != last) {
- const_iterator mid = advance (first, distance (first,last) / 2);
- if (mid->first < k)
- first = advance (mid, 1);
- else
- last = mid;
- }
- return (first);
-}
-
-/// Returns an iterator to the first element with key value \p k.
-template <typename K, typename V>
-typename multimap<K,V>::const_iterator multimap<K,V>::upper_bound (const_key_ref k) const
-{
- const_iterator first (begin()), last (end());
- while (first != last) {
- const_iterator mid = advance (first, distance (first,last) / 2);
- if (k < mid->first)
- last = mid;
- else
- first = advance (mid, 1);
- }
- return (last);
-}
-
-/// Inserts the pair into the container.
-template <typename K, typename V>
-inline typename multimap<K,V>::iterator multimap<K,V>::insert (const_reference v)
-{
- iterator ip = const_cast<iterator> (upper_bound (v.first));
- return (base_class::insert (ip, v));
-}
-
-/// Inserts elements from range [i1,i2) into the container.
-template <typename K, typename V>
-void multimap<K,V>::insert (const_iterator i1, const_iterator i2)
-{
- assert (i1 <= i2);
- reserve (size() + distance (i1, i2));
- for (; i1 != i2; ++i1)
- insert (*i1);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/umultiset.h b/media/libdrm/mobile2/src/util/ustl-1.0/umultiset.h
deleted file mode 100644
index 404b877..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/umultiset.h
+++ /dev/null
@@ -1,106 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// umultiset.h
-//
-
-#ifndef UMULTISET_H_446AEDBB7F61C6994DC228C25D5FA3A1
-#define UMULTISET_H_446AEDBB7F61C6994DC228C25D5FA3A1
-
-#include "uassert.h"
-#include "ualgo.h"
-#include "uvector.h"
-
-namespace ustl {
-
-/// \class multiset umultiset.h ustl.h
-/// \ingroup AssociativeContainers
-///
-/// \brief Multiple sorted container.
-/// Unlike set, it may contain multiple copies of each element.
-///
-template <typename T>
-class multiset : public vector<T> {
-public:
- typedef const multiset<T>& rcself_t;
- typedef vector<T> base_class;
- typedef typename base_class::value_type value_type;
- typedef typename base_class::size_type size_type;
- typedef typename base_class::pointer pointer;
- typedef typename base_class::const_pointer const_pointer;
- typedef typename base_class::reference reference;
- typedef typename base_class::const_reference const_reference;
- typedef typename base_class::const_iterator const_iterator;
- typedef typename base_class::iterator iterator;
- typedef typename base_class::reverse_iterator reverse_iterator;
- typedef typename base_class::const_reverse_iterator const_reverse_iterator;
-public:
- inline multiset (void) : vector<T> () {}
- explicit inline multiset (size_type n) : vector<T> (n) {}
- inline multiset (rcself_t v) : vector<T> (v) {}
- inline multiset (const_iterator i1, const_iterator i2) : vector<T> () { insert (i1, i2); }
- inline rcself_t operator= (rcself_t v) { base_class::operator= (v); return (*this); }
- inline size_type size (void) const { return (base_class::size()); }
- inline iterator begin (void) { return (base_class::begin()); }
- inline const_iterator begin (void) const { return (base_class::begin()); }
- inline iterator end (void) { return (base_class::end()); }
- inline const_iterator end (void) const { return (base_class::end()); }
- inline void assign (const_iterator i1, const_iterator i2);
- size_type count (const_reference v) const;
- inline void push_back (const_reference v) { insert (v); }
- inline iterator insert (const_reference v);
- void insert (const_iterator i1, const_iterator i2);
- void erase (const_reference v);
- inline iterator erase (iterator ep) { return (base_class::erase (ep)); }
- inline iterator erase (iterator ep1, iterator ep2) { return (base_class::erase (ep1, ep2)); }
- inline void clear (void) { base_class::clear(); }
-};
-
-/// Copies contents of range [i1,i2)
-template <typename T>
-inline void multiset<T>::assign (const_iterator i1, const_iterator i2)
-{
- base_class::clear();
- insert (i1, i2);
-}
-
-/// Returns the number of elements of value \p v.
-template <typename T>
-typename multiset<T>::size_type multiset<T>::count (const_reference v) const
-{
- const pair<const_iterator,const_iterator> fr = equal_range (begin(), end(), v);
- return (distance (fr.first, fr.second));
-}
-
-/// Inserts \p v.
-template <typename T>
-inline typename multiset<T>::iterator multiset<T>::insert (const_reference v)
-{
- iterator ip = upper_bound (begin(), end(), v);
- return (base_class::insert (ip, v));
-}
-
-/// Inserts all elements from range [i1,i2).
-template <typename T>
-void multiset<T>::insert (const_iterator i1, const_iterator i2)
-{
- assert (i1 <= i2);
- reserve (size() + distance (i1, i2));
- for (; i1 < i2; ++i1)
- push_back (*i1);
-}
-
-/// Erases all elements with value \p v.
-template <typename T>
-void multiset<T>::erase (const_reference v)
-{
- pair<iterator,iterator> epr = equal_range (begin(), end(), v);
- erase (epr.first, epr.second);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/unew.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/unew.cpp
deleted file mode 100644
index 084e053..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/unew.cpp
+++ /dev/null
@@ -1,33 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// unew.cc
-//
-
-#include "unew.h"
-#include <stdlib.h>
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-#endif
-
-void* throwing_malloc (size_t n) throw (ustl::bad_alloc)
-{
- void* p = malloc (n);
- if (!p)
-#if PLATFORM_ANDROID
- printf("bad alloc\n");
-#else
- throw ustl::bad_alloc (n);
-#endif
- return (p);
-}
-
-void free_nullok (void* p) throw()
-{
- if (p)
- free (p);
-}
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/unew.h b/media/libdrm/mobile2/src/util/ustl-1.0/unew.h
deleted file mode 100644
index c4ffb62..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/unew.h
+++ /dev/null
@@ -1,52 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-/// \file unew.h
-///
-/// \brief Same as \<new\>, but throws ustl:: exceptions.
-//
-
-#ifndef UNEW_H_11D237512B324C9C05A55DAF1BF086F1
-#define UNEW_H_11D237512B324C9C05A55DAF1BF086F1
-
-#include "uexception.h"
-
-/// Just like malloc, but throws on failure.
-void* throwing_malloc (size_t n) throw (ustl::bad_alloc);
-/// Just like free, but doesn't crash when given a NULL.
-void free_nullok (void* p) throw();
-
-#ifdef WITHOUT_LIBSTDCPP
-
-//
-// These are replaceable signatures:
-// - normal single new and delete (no arguments, throw @c bad_alloc on error)
-// - normal array new and delete (same)
-// - @c nothrow single new and delete (take a @c nothrow argument, return
-// @c NULL on error)
-// - @c nothrow array new and delete (same)
-//
-// Placement new and delete signatures (take a memory address argument,
-// does nothing) may not be replaced by a user's program.
-//
-inline void* operator new (size_t n) throw (ustl::bad_alloc) { return (throwing_malloc (n)); }
-inline void* operator new[] (size_t n) throw (ustl::bad_alloc) { return (throwing_malloc (n)); }
-inline void operator delete (void* p) throw() { free_nullok (p); }
-inline void operator delete[] (void* p) throw() { free_nullok (p); }
-
-// Default placement versions of operator new.
-inline void* operator new (size_t, void* p) throw() { return (p); }
-inline void* operator new[] (size_t, void* p) throw() { return (p); }
-
-// Default placement versions of operator delete.
-inline void operator delete (void*, void*) throw() { }
-inline void operator delete[](void*, void*) throw() { }
-
-#else
-#include <new>
-#endif // WITHOUT_LIBSTDCPP
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/unumeric.h b/media/libdrm/mobile2/src/util/ustl-1.0/unumeric.h
deleted file mode 100644
index 4883eb4..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/unumeric.h
+++ /dev/null
@@ -1,160 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// unumeric.h
-//
-// This file contains numeric algorithm templates.
-//
-
-#ifndef UNUMERIC_H_6C99D6F6363832C644A6FFF336E84E18
-#define UNUMERIC_H_6C99D6F6363832C644A6FFF336E84E18
-
-namespace ustl {
-
-/// Returns the sum of all elements in [first, last) added to \p init.
-/// \ingroup NumericAlgorithms
-///
-template <typename InputIterator, typename T>
-inline T accumulate (InputIterator first, InputIterator last, T init)
-{
- while (first < last)
- init += *first++;
- return (init);
-}
-
-/// Returns the sum of all elements in [first, last) via \p op, added to \p init.
-/// \ingroup NumericAlgorithms
-///
-template <typename InputIterator, typename T, typename BinaryFunction>
-inline T accumulate (InputIterator first, InputIterator last, T init, BinaryFunction binary_op)
-{
- while (first < last)
- init = binary_op (init, *first++);
- return (init);
-}
-
-/// Assigns range [value, value + (last - first)) to [first, last)
-/// \ingroup NumericAlgorithms
-///
-template <typename ForwardIterator, typename T>
-inline void iota (ForwardIterator first, ForwardIterator last, T value)
-{
- while (first < last)
- *first++ = value++;
-}
-
-/// Returns the sum of products of respective elements in the given ranges.
-/// \ingroup NumericAlgorithms
-///
-template <typename InputIterator1, typename InputIterator2, typename T>
-inline T inner_product (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, T init)
-{
- while (first1 < last1)
- init += *first1++ * *first2++;
- return (init);
-}
-
-/// Returns the sum of products of respective elements in the given ranges.
-/// \ingroup NumericAlgorithms
-///
-template <typename InputIterator1, typename InputIterator2, typename T,
- typename BinaryOperation1, typename BinaryOperation2>
-inline T inner_product
-(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, T init,
- BinaryOperation1 sumOp, BinaryOperation2 productOp)
-{
- while (first1 < last1)
- init = sumOp (init, productOp (*first1++, *first2++));
- return (init);
-}
-
-/// Writes result such that result[i] = sum (first...first+i)
-/// \ingroup NumericAlgorithms
-///
-template <typename InputIterator, typename OutputIterator>
-inline OutputIterator partial_sum (InputIterator first, InputIterator last, OutputIterator result)
-{
- if (first < last)
- *result = *first++;
- while (first < last)
- *++result = *first++ + *result;
- return (result);
-}
-
-/// Writes result such that result[i] = sumOp (first...first+i)
-/// \ingroup NumericAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename BinaryOperation>
-inline OutputIterator partial_sum (InputIterator first, InputIterator last, OutputIterator result, BinaryOperation sumOp)
-{
- if (first < last)
- *result = *first++;
- while (first < last)
- *++result = sumOp (*first++, *result);
- return (result);
-}
-
-/// Writes result such that result[i] = first[i] - first[i - 1]
-/// \ingroup NumericAlgorithms
-///
-template <typename InputIterator, typename OutputIterator>
-inline OutputIterator adjacent_difference (InputIterator first, InputIterator last, OutputIterator result)
-{
- if (first < last)
- *result++ = *first++;
- while (first < last)
- *result++ = *first - *(first - 1);
- return (result);
-}
-
-/// Writes result such that result[i] = differenceOp (first[i], first[i - 1])
-/// \ingroup NumericAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename BinaryOperation>
-inline OutputIterator adjacent_difference (InputIterator first, InputIterator last, OutputIterator result, BinaryOperation differenceOp)
-{
- if (first < last)
- *result++ = *first++;
- while (first < last)
- *result++ = differenceOp (*first, *(first - 1));
- return (result);
-}
-
-/// \brief Returns x^n.
-/// Donald Knuth's Russian Peasant algorithm.
-/// \ingroup NumericAlgorithms
-///
-template <typename T>
-inline T power (T x, unsigned n)
-{
- T result (n % 2 ? x : 1);
- while (n /= 2) {
- x *= x;
- if (n % 2)
- result *= x;
- }
- return (result);
-}
-
-/// \brief Returns x^n, using \p op instead of multiplication.
-/// Donald Knuth's Russian Peasant algorithm.
-/// \ingroup NumericAlgorithms
-///
-template <typename T, typename BinaryOperation>
-inline T power (T x, unsigned n, BinaryOperation op)
-{
- T result (n % 2 ? x : 1);
- while (n /= 2) {
- x = op (x, x);
- if (n % 2)
- result = op (result, x);
- }
- return (result);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/upair.h b/media/libdrm/mobile2/src/util/ustl-1.0/upair.h
deleted file mode 100644
index b4cc3b7..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/upair.h
+++ /dev/null
@@ -1,63 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-/// \file upair.h
-/// \brief Pair-related functionality.
-
-#ifndef UPAIR_H_7DC08F1B7FECF8AE6856D84C3B617A75
-#define UPAIR_H_7DC08F1B7FECF8AE6856D84C3B617A75
-
-#include "utypes.h"
-
-namespace ustl {
-
-/// \class pair upair.h ustl.h
-/// \ingroup AssociativeContainers
-///
-/// \brief Container for two values.
-///
-template <typename T1, typename T2>
-class pair {
-public:
- typedef T1 first_type;
- typedef T2 second_type;
-public:
- /// Default constructor.
- inline pair (void) : first (T1()), second (T2()) {}
- /// Initializes members with \p a, and \p b.
- inline pair (const T1& a, const T2& b) : first (a), second (b) {}
- inline pair& operator= (const pair<T1, T2>& p2) { first = p2.first; second = p2.second; return (*this); }
- template <typename T3, typename T4>
- inline pair& operator= (const pair<T3, T4>& p2) { first = p2.first; second = p2.second; return (*this); }
-public:
- first_type first;
- second_type second;
-};
-
-/// Compares both values of \p p1 to those of \p p2.
-template <typename T1, typename T2>
-inline bool operator== (const pair<T1,T2>& p1, const pair<T1,T2>& p2)
-{
- return (p1.first == p2.first && p1.second == p2.second);
-}
-
-/// Compares both values of \p p1 to those of \p p2.
-template <typename T1, typename T2>
-bool operator< (const pair<T1,T2>& p1, const pair<T1,T2>& p2)
-{
- return (p1.first < p2.first || (p1.first == p2.first && p1.second < p2.second));
-}
-
-/// Returns a pair object with (a,b)
-template <typename T1, typename T2>
-inline pair<T1,T2> make_pair (const T1& a, const T2& b)
-{
- return (pair<T1,T2> (a, b));
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/upredalgo.h b/media/libdrm/mobile2/src/util/ustl-1.0/upredalgo.h
deleted file mode 100644
index 562a3d6..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/upredalgo.h
+++ /dev/null
@@ -1,597 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ualgo.h
-//
-// Implementation of STL algorithms with custom predicates.
-//
-// The function prototypes are copied
-// exactly from the SGI version of STL documentation along with comments about
-// their use. The code is NOT the same, though the functionality usually is.
-//
-
-#ifndef UPREDALGO_H_2CB058AE0807A01A2F6A51BA5D5820A5
-#define UPREDALGO_H_2CB058AE0807A01A2F6A51BA5D5820A5
-
-namespace ustl {
-
-/// Copy_if copies elements from the range [first, last) to the range
-/// [result, result + (last - first)) if pred(*i) returns true.
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename Predicate>
-inline OutputIterator copy_if (InputIterator first, InputIterator last, OutputIterator result, Predicate pred)
-{
- for (; first != last; ++first) {
- if (pred(*first)) {
- *result = *first;
- ++ result;
- }
- }
- return (result);
-}
-
-/// Returns the first iterator i in the range [first, last) such that
-/// pred(*i) is true. Returns last if no such iterator exists.
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename Predicate>
-inline InputIterator find_if (InputIterator first, InputIterator last, Predicate pred)
-{
- while (first != last && !pred (*first))
- ++ first;
- return (first);
-}
-
-/// Returns the first iterator such that p(*i, *(i + 1)) == true.
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename BinaryPredicate>
-inline ForwardIterator adjacent_find (ForwardIterator first, ForwardIterator last, BinaryPredicate p)
-{
- if (first != last)
- for (ForwardIterator prev = first; ++first != last; ++ prev)
- if (p (*prev, *first))
- return (prev);
- return (last);
-}
-
-/// Returns the pointer to the first pair of unequal elements.
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename BinaryPredicate>
-inline pair<InputIterator,InputIterator>
-mismatch (InputIterator first1, InputIterator last1, InputIterator first2, BinaryPredicate comp)
-{
- while (first1 != last1 && comp(*first1, *first2))
- ++ first1, ++ first2;
- return (make_pair (first1, first2));
-}
-
-/// Returns true if two ranges are equal.
-/// This is an extension, present in uSTL and SGI STL.
-/// \ingroup ConditionAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename BinaryPredicate>
-inline bool equal (InputIterator first1, InputIterator last1, InputIterator first2, BinaryPredicate comp)
-{
- return (mismatch (first1, last1, first2, comp).first == last1);
-}
-
-/// Count_if finds the number of elements in [first, last) that satisfy the
-/// predicate pred. More precisely, the first version of count_if returns the
-/// number of iterators i in [first, last) such that pred(*i) is true.
-/// \ingroup ConditionAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename Predicate>
-inline size_t count_if (InputIterator first, InputIterator last, Predicate pred)
-{
- size_t total = 0;
- for (; first != last; ++first)
- if (pred (*first))
- ++ total;
- return (total);
-}
-
-/// Replace_if replaces every element in the range [first, last) for which
-/// pred returns true with new_value. That is: for every iterator i, if
-/// pred(*i) is true then it performs the assignment *i = new_value.
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename Predicate, typename T>
-inline void replace_if (ForwardIterator first, ForwardIterator last, Predicate pred, const T& new_value)
-{
- for (; first != last; ++first)
- if (pred (*first))
- *first = new_value;
-}
-
-/// Replace_copy_if copies elements from the range [first, last) to the range
-/// [result, result + (last-first)), except that any element for which pred is
-/// true is not copied; new_value is copied instead. More precisely, for every
-/// integer n such that 0 <= n < last-first, replace_copy_if performs the
-/// assignment *(result+n) = new_value if pred(*(first+n)),
-/// and *(result+n) = *(first+n) otherwise.
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename Predicate, typename T>
-inline OutputIterator replace_copy_if (InputIterator first, InputIterator last, OutputIterator result, Predicate pred, const T& new_value)
-{
- for (; first != last; ++result, ++first)
- *result = pred(*first) ? new_value : *first;
-}
-
-/// Remove_copy_if copies elements from the range [first, last) to a range
-/// beginning at result, except that elements for which pred is true are not
-/// copied. The return value is the end of the resulting range. This operation
-/// is stable, meaning that the relative order of the elements that are copied
-/// is the same as in the range [first, last).
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename Predicate>
-inline OutputIterator remove_copy_if (InputIterator first, InputIterator last, OutputIterator result, Predicate pred)
-{
- for (; first != last; ++first)
- if (pred (*first))
- *result++ = *first;
- return (result);
-}
-
-/// Remove_if removes from the range [first, last) every element x such that
-/// pred(x) is true. That is, remove_if returns an iterator new_last such that
-/// the range [first, new_last) contains no elements for which pred is true.
-/// The iterators in the range [new_last, last) are all still dereferenceable,
-/// but the elements that they point to are unspecified. Remove_if is stable,
-/// meaning that the relative order of elements that are not removed is
-/// unchanged.
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename Predicate>
-inline ForwardIterator remove_if (ForwardIterator first, ForwardIterator last, Predicate pred)
-{
- return (remove_copy_if (first, last, first, pred));
-}
-
-/// The reason there are two different versions of unique_copy is that there
-/// are two different definitions of what it means for a consecutive group of
-/// elements to be duplicates. In the first version, the test is simple
-/// equality: the elements in a range [f, l) are duplicates if, for every
-/// iterator i in the range, either i == f or else *i == *(i-1). In the second,
-/// the test is an arbitrary Binary Predicate binary_pred: the elements in
-/// [f, l) are duplicates if, for every iterator i in the range, either
-/// i == f or else binary_pred(*i, *(i-1)) is true.
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename InputIterator, typename OutputIterator, typename BinaryPredicate>
-OutputIterator unique_copy (InputIterator first, InputIterator last, OutputIterator result, BinaryPredicate binary_pred)
-{
- if (first != last) {
- *result = *first;
- while (++first != last)
- if (!binary_pred (*first, *result))
- *++result = *first;
- ++ result;
- }
- return (result);
-}
-
-/// Every time a consecutive group of duplicate elements appears in the range
-/// [first, last), the algorithm unique removes all but the first element.
-/// That is, unique returns an iterator new_last such that the range [first,
-/// new_last) contains no two consecutive elements that are duplicates.
-/// The iterators in the range [new_last, last) are all still dereferenceable,
-/// but the elements that they point to are unspecified. Unique is stable,
-/// meaning that the relative order of elements that are not removed is
-/// unchanged.
-/// \ingroup MutatingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename BinaryPredicate>
-inline ForwardIterator unique (ForwardIterator first, ForwardIterator last, BinaryPredicate binary_pred)
-{
- return (unique_copy (first, last, first, binary_pred));
-}
-
-/// Returns the furthermost iterator i in [first, last) such that,
-/// for every iterator j in [first, i), comp(*j, value) is true.
-/// Assumes the range is sorted.
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename T, typename StrictWeakOrdering>
-ForwardIterator lower_bound (ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp)
-{
- ForwardIterator mid;
- while (first != last) {
- mid = advance (first, distance (first,last) / 2);
- if (comp (*mid, value))
- first = mid + 1;
- else
- last = mid;
- }
- return (first);
-}
-
-/// Performs a binary search inside the sorted range.
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename T, typename StrictWeakOrdering>
-inline ForwardIterator binary_search (ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp)
-{
- ForwardIterator found = lower_bound (first, last, value, comp);
- return ((found == last || comp(value, *found)) ? last : found);
-}
-
-/// Returns the furthermost iterator i in [first,last) such that for
-/// every iterator j in [first,i), comp(value,*j) is false.
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename T, typename StrictWeakOrdering>
-ForwardIterator upper_bound (ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp)
-{
- ForwardIterator mid;
- while (first != last) {
- mid = advance (first, distance (first,last) / 2);
- if (comp (value, *mid))
- last = mid;
- else
- first = mid + 1;
- }
- return (last);
-}
-
-/// Returns pair<lower_bound,upper_bound>
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename ForwardIterator, typename T, typename StrictWeakOrdering>
-inline pair<ForwardIterator,ForwardIterator> equal_range (ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp)
-{
- pair<ForwardIterator,ForwardIterator> rv;
- rv.second = rv.first = lower_bound (first, last, value, comp);
- while (rv.second != last && !comp(value, *(rv.second)))
- ++ rv.second;
- return (rv);
-}
-
-/// \brief Puts \p nth element into its sorted position.
-/// In this implementation, the entire array is sorted. The performance difference is
-/// so small and the function use is so rare, there is no need to have code for it.
-/// \ingroup SortingAlgorithms
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-///
-template <typename RandomAccessIterator, typename Compare>
-inline void nth_element (RandomAccessIterator first, RandomAccessIterator, RandomAccessIterator last, Compare comp)
-{
- sort (first, last, comp);
-}
-
-/// \brief Searches for the first subsequence [first2,last2) in [first1,last1)
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename ForwardIterator1, typename ForwardIterator2, typename BinaryPredicate>
-ForwardIterator1 search (ForwardIterator1 first1, ForwardIterator1 last1, ForwardIterator2 first2, ForwardIterator2 last2, BinaryPredicate comp)
-{
- const ForwardIterator1 slast = last1 - distance(first2, last2) + 1;
- for (; first1 < slast; ++first1) {
- ForwardIterator2 i = first2;
- ForwardIterator1 j = first1;
- for (; i != last2 && comp(*j, *i); ++i, ++j);
- if (i == last2)
- return (first1);
- }
- return (last1);
-}
-
-/// \brief Searches for the last subsequence [first2,last2) in [first1,last1)
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename ForwardIterator1, typename ForwardIterator2, typename BinaryPredicate>
-ForwardIterator1 find_end (ForwardIterator1 first1, ForwardIterator1 last1, ForwardIterator2 first2, ForwardIterator2 last2, BinaryPredicate comp)
-{
- ForwardIterator1 s = last1 - distance(first2, last2);
- for (; first1 < s; --s) {
- ForwardIterator2 i = first2, j = s;
- for (; i != last2 && comp(*j, *i); ++i, ++j);
- if (i == last2)
- return (s);
- }
- return (last1);
-}
-
-/// \brief Searches for the first occurence of \p count \p values in [first, last)
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename Iterator, typename T, typename BinaryPredicate>
-Iterator search_n (Iterator first, Iterator last, size_t count, const T& value, BinaryPredicate comp)
-{
- size_t n = 0;
- for (; first != last; ++first) {
- if (!comp (*first, value))
- n = 0;
- else if (++n == count)
- return (first - --n);
- }
- return (last);
-}
-
-/// \brief Searches [first1,last1) for the first occurrence of an element from [first2,last2)
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename InputIterator, typename ForwardIterator, typename BinaryPredicate>
-InputIterator find_first_of (InputIterator first1, InputIterator last1, ForwardIterator first2, ForwardIterator last2, BinaryPredicate comp)
-{
- for (; first1 != last1; ++first1)
- for (ForwardIterator i = first2; i != last2; ++i)
- if (comp (*first1, *i))
- return (first1);
- return (first1);
-}
-
-/// \brief Returns true if [first2,last2) is a subset of [first1,last1)
-/// \ingroup ConditionAlgorithms
-/// \ingroup SetAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename StrictWeakOrdering>
-bool includes (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, StrictWeakOrdering comp)
-{
- for (; (first1 != last1) & (first2 != last2); ++first1) {
- if (comp (*first2, *first1))
- return (false);
- first2 += !comp (*first1, *first2);
- }
- return (first2 == last2);
-}
-
-/// \brief Merges [first1,last1) with [first2,last2)
-///
-/// Result will contain every element that is in either set. If duplicate
-/// elements are present, max(n,m) is placed in the result.
-///
-/// \ingroup SetAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator, typename StrictWeakOrdering>
-OutputIterator set_union (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result, StrictWeakOrdering comp)
-{
- for (; (first1 != last1) & (first2 != last2); ++result) {
- if (comp (*first2, *first1))
- *result = *first2++;
- else {
- first2 += !comp (*first1, *first2);
- *result = *first1++;
- }
- }
- return (copy (first2, last2, copy (first1, last1, result)));
-}
-
-/// \brief Creates a set containing elements shared by the given ranges.
-/// \ingroup SetAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator, typename StrictWeakOrdering>
-OutputIterator set_intersection (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result, StrictWeakOrdering comp)
-{
- while ((first1 != last1) & (first2 != last2)) {
- bool b1ge2 = !comp (*first1, *first2), b2ge1 = !comp (*first2, *first1);
- if (b1ge2 & b2ge1)
- *result++ = *first1;
- first1 += b2ge1;
- first2 += b1ge2;
- }
- return (result);
-}
-
-/// \brief Removes from [first1,last1) elements present in [first2,last2)
-/// \ingroup SetAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator, typename StrictWeakOrdering>
-OutputIterator set_difference (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result, StrictWeakOrdering comp)
-{
- while ((first1 != last1) & (first2 != last2)) {
- bool b1ge2 = !comp (*first1, *first2), b2ge1 = !comp (*first2, *first1);
- if (!b1ge2)
- *result++ = *first1;
- first1 += b2ge1;
- first2 += b1ge2;
- }
- return (copy (first1, last1, result));
-}
-
-/// \brief Performs union of sets A-B and B-A.
-/// \ingroup SetAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename OutputIterator, typename StrictWeakOrdering>
-OutputIterator set_symmetric_difference (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result, StrictWeakOrdering comp)
-{
- while ((first1 != last1) & (first2 != last2)) {
- bool b1l2 = comp (*first1, *first2), b2l1 = comp (*first2, *first1);
- if (b1l2)
- *result++ = *first1;
- else if (b2l1)
- *result++ = *first2;
- first1 += !b2l1;
- first2 += !b1l2;
- }
- return (copy (first2, last2, copy (first1, last1, result)));
-}
-
-/// \brief Returns true if the given range is sorted.
-/// \ingroup ConditionAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename ForwardIterator, typename StrictWeakOrdering>
-bool is_sorted (ForwardIterator first, ForwardIterator last, StrictWeakOrdering comp)
-{
- for (ForwardIterator i = first; ++i < last; ++first)
- if (comp (*i, *first))
- return (false);
- return (true);
-}
-
-/// \brief Compares two given containers like strcmp compares strings.
-/// \ingroup ConditionAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename InputIterator1, typename InputIterator2, typename BinaryPredicate>
-bool lexicographical_compare (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, BinaryPredicate comp)
-{
- for (; (first1 != last1) & (first2 != last2); ++first1, ++first2) {
- if (comp (*first1, *first2))
- return (true);
- if (comp (*first2, *first1))
- return (false);
- }
- return ((first1 == last1) & (first2 != last2));
-}
-
-/// \brief Creates the next lexicographical permutation of [first,last).
-/// Returns false if no further permutations can be created.
-/// \ingroup GeneratorAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename BidirectionalIterator, typename StrictWeakOrdering>
-bool next_permutation (BidirectionalIterator first, BidirectionalIterator last, StrictWeakOrdering comp)
-{
- if (distance (first, last) < 2)
- return (false);
- BidirectionalIterator i = last;
- for (--i; i != first; ) {
- --i;
- if (comp (i[0], i[1])) {
- BidirectionalIterator j = last;
- while (!comp (*i, *--j));
- iter_swap (i, j);
- reverse (i + 1, last);
- return (true);
- }
- }
- reverse (first, last);
- return (false);
-}
-
-/// \brief Creates the previous lexicographical permutation of [first,last).
-/// Returns false if no further permutations can be created.
-/// \ingroup GeneratorAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename BidirectionalIterator, typename StrictWeakOrdering>
-bool prev_permutation (BidirectionalIterator first, BidirectionalIterator last, StrictWeakOrdering comp)
-{
- if (distance (first, last) < 2)
- return (false);
- BidirectionalIterator i = last;
- for (--i; i != first; ) {
- --i;
- if (comp(i[1], i[0])) {
- BidirectionalIterator j = last;
- while (!comp (*--j, *i));
- iter_swap (i, j);
- reverse (i + 1, last);
- return (true);
- }
- }
- reverse (first, last);
- return (false);
-}
-
-/// \brief Returns iterator to the max element in [first,last)
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename ForwardIterator, typename BinaryPredicate>
-inline ForwardIterator max_element (ForwardIterator first, ForwardIterator last, BinaryPredicate comp)
-{
- ForwardIterator result = first;
- for (; first != last; ++first)
- if (comp (*result, *first))
- result = first;
- return (result);
-}
-
-/// \brief Returns iterator to the min element in [first,last)
-/// \ingroup SearchingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename ForwardIterator, typename BinaryPredicate>
-inline ForwardIterator min_element (ForwardIterator first, ForwardIterator last, BinaryPredicate comp)
-{
- ForwardIterator result = first;
- for (; first != last; ++first)
- if (comp (*first, *result))
- result = first;
- return (result);
-}
-
-/// \brief Makes [first,middle) a part of the sorted array.
-/// Contents of [middle,last) is undefined. This implementation just calls stable_sort.
-/// \ingroup SortingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename RandomAccessIterator, typename StrictWeakOrdering>
-inline void partial_sort (RandomAccessIterator first, RandomAccessIterator, RandomAccessIterator last, StrictWeakOrdering comp)
-{
- stable_sort (first, last, comp);
-}
-
-/// \brief Like partial_sort, but outputs to [result_first,result_last)
-/// \ingroup SortingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename InputIterator, typename RandomAccessIterator, typename StrictWeakOrdering>
-RandomAccessIterator partial_sort_copy (InputIterator first, InputIterator last, RandomAccessIterator result_first, RandomAccessIterator result_last, StrictWeakOrdering comp)
-{
- RandomAccessIterator rend = result_first;
- for (; first != last; ++first) {
- RandomAccessIterator i = result_first;
- for (; i != rend && comp (*i, *first); ++i);
- if (i == result_last)
- continue;
- rend += (rend < result_last);
- copy_backward (i, rend - 1, rend);
- *i = *first;
- }
- return (rend);
-}
-
-/// \brief Like \ref partition, but preserves equal element order.
-/// \ingroup SortingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename ForwardIterator, typename Predicate>
-ForwardIterator stable_partition (ForwardIterator first, ForwardIterator last, Predicate pred)
-{
- if (first == last)
- return (first);
- ForwardIterator l, r, m = advance (first, distance (first, last) / 2);
- if (first == m)
- return (pred(*first) ? last : first);
- l = stable_partition (first, m, pred);
- r = stable_partition (m, last, pred);
- rotate (l, m, r);
- return (advance (l, distance (m, r)));
-}
-
-/// \brief Splits [first,last) in two by \p pred.
-///
-/// Creates two ranges [first,middle) and [middle,last), where every element
-/// in the former is less than every element in the latter.
-/// The return value is middle.
-///
-/// \ingroup SortingAlgorithms
-/// \ingroup PredicateAlgorithms
-template <typename ForwardIterator, typename Predicate>
-inline ForwardIterator partition (ForwardIterator first, ForwardIterator last, Predicate pred)
-{
- return (stable_partition (first, last, pred));
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uqueue.h b/media/libdrm/mobile2/src/util/ustl-1.0/uqueue.h
deleted file mode 100644
index 99eef80..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uqueue.h
+++ /dev/null
@@ -1,71 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uqueue.h
-//
-
-#ifndef UQUEUE_H_27F01FDB0D59B75277E0E5C41ABC6B5B
-#define UQUEUE_H_27F01FDB0D59B75277E0E5C41ABC6B5B
-
-namespace ustl {
-
-/// \class queue uqueue.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief Queue adapter to uSTL containers.
-///
-/// The most efficient way to use this implementation is to fill the queue
-/// and the completely empty it before filling again.
-///
-template <typename Sequence>
-class queue {
-public:
- typedef typename Sequence::value_type value_type;
- typedef typename Sequence::size_type size_type;
- typedef typename Sequence::difference_type difference_type;
- typedef typename Sequence::reference reference;
- typedef typename Sequence::const_reference const_reference;
- typedef typename Sequence::pointer pointer;
-public:
- inline queue (void) : m_Storage (), m_Front (0) { }
- explicit inline queue (const Sequence& s) : m_Storage (s), m_Front (0) { }
- inline size_type size (void) const { return (m_Storage.size() - m_Front); }
- inline bool empty (void) const { return (!size()); }
- inline reference front (void) { return (m_Storage [m_Front]); }
- inline const_reference front (void) const { return (m_Storage [m_Front]); }
- inline reference back (void) { return (m_Storage.back()); }
- inline const_reference back (void) const { return (m_Storage.back()); }
- inline void push (const value_type& v);
- inline void pop (void);
- inline bool operator== (const queue& s) { return (m_Storage == s.m_Storage && m_Front == s.m_Front); }
- inline bool operator< (const queue& s) { return (size() < s.size()); }
-private:
- Sequence m_Storage; ///< Where the data actually is.
- size_type m_Front; ///< Index of the element returned by next pop.
-};
-
-/// Pushes \p v on the queue.
-template <class Sequence>
-inline void queue<Sequence>::push (const value_type& v)
-{
- if (m_Front) {
- m_Storage.erase (m_Storage.begin(), m_Front);
- m_Front = 0;
- }
- m_Storage.push_back (v);
-}
-
-/// Pops the topmost element from the queue.
-template <class Sequence>
-inline void queue<Sequence>::pop (void)
-{
- if (++m_Front >= m_Storage.size())
- m_Storage.resize (m_Front = 0);
-}
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uset.h b/media/libdrm/mobile2/src/util/ustl-1.0/uset.h
deleted file mode 100644
index 958d4b0..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uset.h
+++ /dev/null
@@ -1,97 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uset.h
-//
-
-#ifndef USET_H_45543F516E02A87A3FCEA5024052A6F5
-#define USET_H_45543F516E02A87A3FCEA5024052A6F5
-
-#include "uassert.h"
-#include "uvector.h"
-
-namespace ustl {
-
-/// \class set uset.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief Unique sorted container. Sorted vector with all values unique.
-///
-template <typename T>
-class set : public vector<T> {
-public:
- typedef const set<T>& rcself_t;
- typedef vector<T> base_class;
- typedef typename base_class::value_type key_type;
- typedef typename base_class::value_type data_type;
- typedef typename base_class::value_type value_type;
- typedef typename base_class::size_type size_type;
- typedef typename base_class::pointer pointer;
- typedef typename base_class::const_pointer const_pointer;
- typedef typename base_class::reference reference;
- typedef typename base_class::const_reference const_reference;
- typedef typename base_class::const_iterator const_iterator;
- typedef typename base_class::iterator iterator;
- typedef typename base_class::reverse_iterator reverse_iterator;
- typedef typename base_class::const_reverse_iterator const_reverse_iterator;
-public:
- inline set (void) : vector<T> () { }
- explicit inline set (size_type n) : vector<T> (n) { }
- inline set (rcself_t v) : vector<T> (v) { }
- inline set (const_iterator i1, const_iterator i2) : vector<T> () { insert (i1, i2); }
- inline rcself_t operator= (rcself_t v) { base_class::operator= (v); return (*this); }
- inline size_type size (void) const { return (base_class::size()); }
- inline iterator begin (void) { return (base_class::begin()); }
- inline const_iterator begin (void) const { return (base_class::begin()); }
- inline iterator end (void) { return (base_class::end()); }
- inline const_iterator end (void) const { return (base_class::end()); }
- inline void assign (const_iterator i1, const_iterator i2) { clear(); insert (i1, i2); }
- inline void push_back (const_reference v) { insert (v); }
- inline const_iterator find (const_reference v) const { return (binary_search (begin(), end(), v)); }
- inline iterator find (const_reference v) { return (const_cast<iterator>(const_cast<rcself_t>(*this).find (v))); }
- iterator insert (const_reference v);
- inline void insert (const_iterator i1, const_iterator i2);
- inline void erase (const_reference v);
- inline iterator erase (iterator ep) { return (base_class::erase (ep)); }
- inline iterator erase (iterator ep1, iterator ep2) { return (base_class::erase (ep1, ep2)); }
- inline void clear (void) { base_class::clear(); }
-};
-
-/// Inserts \p v into the container, maintaining the sort order.
-template <typename T>
-typename set<T>::iterator set<T>::insert (const_reference v)
-{
- iterator ip = lower_bound (begin(), end(), v);
- if (ip == end() || v < *ip)
- ip = base_class::insert (ip, v);
- else
- *ip = v;
- return (ip);
-}
-
-/// Inserts the contents of range [i1,i2)
-template <typename T>
-void set<T>::insert (const_iterator i1, const_iterator i2)
-{
- assert (i1 <= i2);
- reserve (size() + distance (i1, i2));
- for (; i1 < i2; ++i1)
- push_back (*i1);
-}
-
-/// Erases the element with value \p v.
-template <typename T>
-inline void set<T>::erase (const_reference v)
-{
- iterator ip = find (v);
- if (ip != end())
- erase (ip);
-}
-
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uspecial.h b/media/libdrm/mobile2/src/util/ustl-1.0/uspecial.h
deleted file mode 100644
index 0b87a54..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uspecial.h
+++ /dev/null
@@ -1,267 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uspecial.h
-//
-// Template specializations for uSTL classes.
-//
-
-#ifndef USPECIAL_H_947ADYOU0ARE3YOU2REALLY8ARE44CE0
-#define USPECIAL_H_947ADYOU0ARE3YOU2REALLY8ARE44CE0
-
-#include "uassert.h"
-#include "uvector.h"
-#include "ustring.h"
-#include "uset.h"
-#include "umultiset.h"
-#include "ubitset.h"
-#include "ulaalgo.h"
-#include "uctralgo.h"
-#include "ufunction.h"
-#include "uctrstrm.h"
-#include "sistream.h"
-#include <ctype.h>
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-// Alogrithm specializations not in use by the library code.
-//----------------------------------------------------------------------
-
-template <> inline void swap (cmemlink& a, cmemlink& b) { a.swap (b); }
-template <> inline void swap (memlink& a, memlink& b) { a.swap (b); }
-template <> inline void swap (memblock& a, memblock& b) { a.swap (b); }
-template <> inline void swap (string& a, string& b) { a.swap (b); }
-#define TEMPLATE_SWAP_PSPEC(type, template_decl) \
-template_decl inline void swap (type& a, type& b) { a.swap (b); }
-TEMPLATE_SWAP_PSPEC (TEMPLATE_TYPE1 (vector,T), TEMPLATE_DECL1 (T))
-TEMPLATE_SWAP_PSPEC (TEMPLATE_TYPE1 (set,T), TEMPLATE_DECL1 (T))
-TEMPLATE_SWAP_PSPEC (TEMPLATE_TYPE1 (multiset,T), TEMPLATE_DECL1 (T))
-TEMPLATE_SWAP_PSPEC (TEMPLATE_TYPE2 (tuple,N,T), TEMPLATE_FULL_DECL2 (size_t,N,typename,T))
-
-//----------------------------------------------------------------------
-// Streamable definitions. Not used in the library and require streams.
-//----------------------------------------------------------------------
-
-//----{ pair }----------------------------------------------------------
-
-/// \brief Reads pair \p p from stream \p is.
-template <typename T1, typename T2>
-istream& operator>> (istream& is, pair<T1,T2>& p)
-{
- is >> p.first;
- is.align (alignof(T2()));
- is >> p.second;
- is.align (alignof(T1()));
- return (is);
-}
-
-/// Writes pair \p p to stream \p os.
-template <typename T1, typename T2>
-ostream& operator<< (ostream& os, const pair<T1,T2>& p)
-{
- os << p.first;
- os.align (alignof(T2()));
- os << p.second;
- os.align (alignof(T1()));
- return (os);
-}
-
-/// Writes pair \p p to stream \p os.
-template <typename T1, typename T2>
-ostringstream& operator<< (ostringstream& os, const pair<T1,T2>& p)
-{
- os << '(' << p.first << ',' << p.second << ')';
- return (os);
-}
-
-/// Returns the written size of the object.
-template <typename T1, typename T2>
-inline size_t stream_size_of (const pair<T1,T2>& v)
-{
- return (Align (stream_size_of(v.first), alignof(T2())) +
- Align (stream_size_of(v.second), alignof(T1())));
-}
-
-/// \brief Takes a pair and returns pair.first
-/// This is an extension, available in uSTL and the SGI STL.
-template <typename Pair> struct select1st : public unary_function<Pair,typename Pair::first_type> {
- typedef typename Pair::first_type result_type;
- inline const result_type& operator()(const Pair& a) const { return (a.first); }
- inline result_type& operator()(Pair& a) const { return (a.first); }
-};
-
-/// \brief Takes a pair and returns pair.second
-/// This is an extension, available in uSTL and the SGI STL.
-template <typename Pair> struct select2nd : public unary_function<Pair,typename Pair::second_type> {
- typedef typename Pair::second_type result_type;
- inline const result_type& operator()(const Pair& a) const { return (a.second); }
- inline result_type& operator()(Pair& a) const { return (a.second); }
-};
-
-/// \brief Converts a const_iterator pair into an iterator pair
-/// Useful for converting pair ranges returned by equal_range, for instance.
-/// This is an extension, available in uSTL.
-template <typename Container>
-inline pair<typename Container::iterator, typename Container::iterator>
-unconst (const pair<typename Container::const_iterator, typename Container::const_iterator>& i, Container& ctr)
-{
- assert (i.first >= ctr.begin() && i.first <= ctr.end() && "unconst algorithm must be given iterators from the argument container");
- pair<typename Container::iterator, typename Container::iterator> result;
- result.first = ctr.begin() + (i.first - ctr.begin());
- result.second = ctr.begin() + (i.second - ctr.begin());
- return (result);
-}
-
-//----{ vector }--------------------------------------------------------
-
-STD_TEMPLATE_CTR_STREAMABLE (TEMPLATE_TYPE1 (vector,T), TEMPLATE_DECL1 (T))
-
-template <typename T>
-inline size_t alignof (const vector<T>&)
-{
- typedef typename vector<T>::written_size_type written_size_type;
- return (alignof (written_size_type()));
-}
-
-//----{ bitset }--------------------------------------------------------
-
-/// Reads bitset \p v from stream \p is.
-template <size_t Size>
-inline istream& operator>> (istream& is, bitset<Size>& v)
-{
- return (nr_container_read (is, v));
-}
-
-/// Writes bitset \p v into stream \p os.
-template <size_t Size>
-inline ostream& operator<< (ostream& os, const bitset<Size>& v)
-{
- return (nr_container_write (os, v));
-}
-
-/// Writes bitset \p v into stream \p os.
-template <size_t Size>
-inline ostringstream& operator<< (ostringstream& os, const bitset<Size>& v)
-{
- return (os << v.to_string());
-}
-
-/// Writes bitset \p v into stream \p os.
-template <size_t Size>
-istringstream& operator>> (istringstream& is, bitset<Size>& v)
-{
- char c;
- for (int i = Size; --i >= 0 && (is >> c).good();)
- v.set (i, c == '1');
- return (is);
-}
-
-/// Returns the number of bytes necessary to write this object to a stream
-template <size_t Size>
-inline size_t stream_size_of (const bitset<Size>& v)
-{
- return (v.capacity() / CHAR_BIT);
-}
-
-//----{ tuple }---------------------------------------------------------
-
-STD_TEMPLATE_NR_CTR_STREAMABLE (
- TEMPLATE_TYPE2 (tuple,N,T),
- TEMPLATE_FULL_DECL2 (size_t,N,typename,T)
-)
-
-template <size_t N, typename T>
-struct numeric_limits<tuple<N,T> > {
- typedef numeric_limits<T> value_limits;
- static inline tuple<N,T> min (void) { tuple<N,T> v; fill (v, value_limits::min()); return (v); }
- static inline tuple<N,T> max (void) { tuple<N,T> v; fill (v, value_limits::max()); return (v); }
- static const bool is_signed = value_limits::is_signed;
- static const bool is_integer = value_limits::is_integer;
- static const bool is_integral = value_limits::is_integral;
-};
-
-template <size_t N, typename T>
-inline size_t alignof (const tuple<N,T>&) { return (alignof (T())); }
-
-template <typename T, typename IntT>
-inline ostringstream& chartype_text_write (ostringstream& os, const T& v)
-{
- if (isprint(v))
- os << '\'' << v << '\'';
- else
- os << (IntT)(v);
- return (os);
-}
-
-template <>
-inline ostringstream& container_element_text_write (ostringstream& os, const uint8_t& v)
-{ return (chartype_text_write<uint8_t, unsigned int> (os, v)); }
-template <>
-inline ostringstream& container_element_text_write (ostringstream& os, const int8_t& v)
-{ return (chartype_text_write<int8_t, int> (os, v)); }
-
-//----{ matrix }--------------------------------------------------------
-
-/// Writes tuple \p v into stream \p os.
-template <size_t NX, size_t NY, typename T>
-ostringstream& operator<< (ostringstream& os, const matrix<NX,NY,T>& v)
-{
- os << '(';
- for (uoff_t row = 0; row < NY; ++ row) {
- os << '(';
- for (uoff_t column = 0; column < NX; ++ column) {
- os << v[row][column];
- if (column < NX - 1)
- os << ',';
- }
- os << ')';
- }
- os << ')';
- return (os);
-}
-
-//----------------------------------------------------------------------
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-#ifndef WITHOUT_LIBSTDCPP
-
-/// \todo Need a better solution to getting the hash value.
-inline hashvalue_t hash_value (const string::const_pointer& v)
-{
- string::const_pointer first (v), last (v + strlen(v));
- hashvalue_t h = 0;
- // This has the bits flowing into each other from both sides of the number
- for (; first < last; ++ first)
- h = *first + ((h << 7) | (h >> BitsInType(hashvalue_t) - 7));
- return (h);
-}
-
-#endif
-#endif
-
-//----------------------------------------------------------------------
-
-} // namespace ustl
-
-// This is here because there really is no other place to put it.
-#if SIZE_OF_BOOL != SIZE_OF_CHAR
-// bool is a big type on some machines (like DEC Alpha), so it's written as a byte.
-ALIGNOF(bool, sizeof(uint8_t))
-#endif
-STD_STREAMABLE(cmemlink)
-STD_STREAMABLE(istream)
-STD_STREAMABLE(ostream)
-STD_STREAMABLE(string)
-STD_STREAMABLE(exception)
-STD_STREAMABLE(CBacktrace)
-TEXT_STREAMABLE(cmemlink)
-TEXT_STREAMABLE(istream)
-TEXT_STREAMABLE(ostream)
-TEXT_STREAMABLE(exception)
-TEXT_STREAMABLE(CBacktrace)
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ustack.h b/media/libdrm/mobile2/src/util/ustl-1.0/ustack.h
deleted file mode 100644
index c48e3b3..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ustack.h
+++ /dev/null
@@ -1,46 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ustack.h
-//
-
-#ifndef USTACK_H_5242F5635322B2EC44A9AEE73022C6E9
-#define USTACK_H_5242F5635322B2EC44A9AEE73022C6E9
-
-namespace ustl {
-
-/// \class stack ustack.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief Stack adapter to uSTL containers.
-///
-template <typename Sequence>
-class stack {
-public:
- typedef typename Sequence::value_type value_type;
- typedef typename Sequence::size_type size_type;
- typedef typename Sequence::difference_type difference_type;
- typedef typename Sequence::reference reference;
- typedef typename Sequence::const_reference const_reference;
- typedef typename Sequence::pointer pointer;
-public:
- inline stack (void) : m_Storage () { }
- explicit inline stack (const Sequence& s) : m_Storage (s) { }
- inline bool empty (void) const { return (m_Storage.empty()); }
- inline size_type size (void) const { return (m_Storage.size()); }
- inline reference top (void) { return (m_Storage.back()); }
- inline const_reference top (void) const { return (m_Storage.back()); }
- inline void push (const value_type& v) { m_Storage.push_back (v); }
- inline void pop (void) { m_Storage.pop_back(); }
- inline bool operator== (const stack& s) { return (m_Storage == s.m_Storage); }
- inline bool operator< (const stack& s) { return (m_Storage.size() < s.m_Storage.size()); }
-private:
- Sequence m_Storage; ///< Where the data actually is.
-};
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ustdxept.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/ustdxept.cpp
deleted file mode 100644
index ce731f7..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ustdxept.cpp
+++ /dev/null
@@ -1,72 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ustdxept.cc
-//
-
-#include "ustdxept.h"
-#include "mistream.h"
-#include "mostream.h"
-#include "strmsize.h"
-#include "uiosfunc.h"
-#include "uspecial.h"
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-
-/// \p arg contains a description of the error.
-error_message::error_message (const char* arg) throw()
-: m_Arg ()
-{
-#if PLATFORM_ANDROID
- m_Arg = arg;
-#else /* !PLATFORM_ANDROID */
- try { m_Arg = arg; } catch (...) {}
-#endif
- set_format (xfmt_ErrorMessage);
-}
-
-/// Virtual destructor
-error_message::~error_message (void) throw()
-{
-}
-
-/// Returns a descriptive error message. fmt="%s: %s"
-void error_message::info (string& msgbuf, const char* fmt) const throw()
-{
- if (!fmt) fmt = "%s: %s";
-#if PLATFORM_ANDROID
- msgbuf.format (fmt, what(), m_Arg.cdata());
-#else /* !PLATFORM_ANDROID */
- try { msgbuf.format (fmt, what(), m_Arg.cdata()); } catch (...) {}
-#endif
-}
-
-/// Reads the object from stream \p is.
-void error_message::read (istream& is)
-{
- exception::read (is);
- is >> m_Arg >> ios::align();
-}
-
-/// Writes the object to stream \p os.
-void error_message::write (ostream& os) const
-{
- exception::write (os);
- os << m_Arg << ios::align();
-}
-
-/// Returns the size of the written object.
-size_t error_message::stream_size (void) const
-{
- return (exception::stream_size() + Align (stream_size_of (m_Arg)));
-}
-
-//----------------------------------------------------------------------
-
-} // namespace ustl
-
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ustdxept.h b/media/libdrm/mobile2/src/util/ustl-1.0/ustdxept.h
deleted file mode 100644
index 4f50953..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ustdxept.h
+++ /dev/null
@@ -1,143 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ustdxept.h
-//
-
-#ifndef USTDXEPT_H_46F7AE967738B588038F95E41158D7FF
-#define USTDXEPT_H_46F7AE967738B588038F95E41158D7FF
-
-#include "uexception.h"
-#include "ustring.h"
-
-namespace ustl {
-
-enum {
- xfmt_ErrorMessage = 2,
- xfmt_LogicError = xfmt_ErrorMessage,
- xfmt_RuntimeError = xfmt_ErrorMessage
-};
-
-/// \class logic_error ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Logic errors represent problems in the internal logic of the program.
-///
-class error_message : public exception {
-public:
- explicit error_message (const char* arg) throw();
- virtual ~error_message (void) throw();
- inline virtual const char* what (void) const throw() { return ("error"); }
- virtual void info (string& msgbuf, const char* fmt = NULL) const throw();
- virtual void read (istream& is);
- virtual void write (ostream& os) const;
- virtual size_t stream_size (void) const;
-protected:
- string m_Arg;
-};
-
-/// \class logic_error ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Logic errors represent problems in the internal logic of the program.
-///
-class logic_error : public error_message {
-public:
- inline explicit logic_error (const char* arg) throw() : error_message (arg) {}
- inline virtual const char* what (void) const throw() { return ("logic error"); }
-};
-
-/// \class domain_error ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Reports domain errors ("domain" is in the mathematical sense)
-///
-class domain_error : public logic_error {
-public:
- inline explicit domain_error (const char* arg) throw() : logic_error (arg) {}
- inline virtual const char* what (void) const throw() { return ("domain error"); }
-};
-
-/// \class invalid_argument ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Reports an invalid argument to a function.
-///
-class invalid_argument : public logic_error {
-public:
- inline explicit invalid_argument (const char* arg) throw() : logic_error (arg) {}
- inline virtual const char* what (void) const throw() { return ("invalid argument"); }
-};
-
-/// \class length_error ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Reports when an object exceeds its allowed size.
-///
-class length_error : public logic_error {
-public:
- inline explicit length_error (const char* arg) throw() : logic_error (arg) {}
- inline virtual const char* what (void) const throw() { return ("length error"); }
-};
-
-/// \class out_of_range ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Reports arguments with values out of allowed range.
-///
-class out_of_range : public logic_error {
-public:
- inline explicit out_of_range (const char* arg) throw() : logic_error (arg) {}
- inline virtual const char* what (void) const throw() { return ("out of range"); }
-};
-
-/// \class runtime_error ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Reports errors that are dependent on the data being processed.
-///
-class runtime_error : public error_message {
-public:
- inline explicit runtime_error (const char* arg) throw() : error_message (arg) {}
- inline virtual const char* what (void) const throw() { return ("runtime error"); }
-};
-
-/// \class range_error ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Reports data that does not fall within the permitted range.
-///
-class range_error : public runtime_error {
-public:
- inline explicit range_error (const char* arg) throw() : runtime_error (arg) {}
- inline virtual const char* what (void) const throw() { return ("range error"); }
-};
-
-/// \class overflow_error ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Reports arithmetic overflow.
-///
-class overflow_error : public runtime_error {
-public:
- inline explicit overflow_error (const char* arg) throw() : runtime_error (arg) {}
- inline virtual const char* what (void) const throw() { return ("overflow error"); }
-};
-
-/// \class underflow_error ustdxept.h ustl.h
-/// \ingroup Exceptions
-///
-/// \brief Reports arithmetic underflow.
-///
-class underflow_error : public runtime_error {
-public:
- inline explicit underflow_error (const char* arg) throw() : runtime_error (arg) {}
- inline virtual const char* what (void) const throw() { return ("underflow error"); }
-};
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ustl.tbff b/media/libdrm/mobile2/src/util/ustl-1.0/ustl.tbff
deleted file mode 100644
index b8ad374..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ustl.tbff
+++ /dev/null
@@ -1,84 +0,0 @@
-<!-- ANSI Standard fixed size types -->
-<type name=int8_t format=signedIntegral size=int8_t/>
-<type name=int16_t format=signedIntegral size=int16_t/>
-<type name=int32_t format=signedIntegral size=int32_t/>
-<type name=int64_t format=signedIntegral size=int64_t/>
-<type name=uint8_t format=integral size=int8_t/>
-<type name=uint16_t format=integral size=int16_t/>
-<type name=uint32_t format=integral size=int32_t/>
-<type name=uint64_t format=integral size=int64_t/>
-<type name=float format=float size=float/>
-<type name=double format=float size=double/>
-
-<!-- Standard types of variable size, these are machine specific -->
-<type name=int_least8_t format=signedIntegral size=int8_t/>
-<type name=int_least16_t format=signedIntegral size=int16_t/>
-<type name=int_least32_t format=signedIntegral size=int32_t/>
-<type name=int_least64_t format=signedIntegral size=int64_t/>
-<type name=uint_least8_t format=integral size=int8_t/>
-<type name=uint_least16_t format=integral size=int16_t/>
-<type name=uint_least32_t format=integral size=int32_t/>
-<type name=uint_least64_t format=integral size=int64_t/>
-<type name=int_fast8_t format=signedIntegral size=int8_t/>
-<type name=int_fast16_t format=signedIntegral size=int16_t/>
-<type name=int_fast32_t format=signedIntegral size=int32_t/>
-<type name=int_fast64_t format=signedIntegral size=int64_t/>
-<type name=uint_fast8_t format=integral size=int8_t/>
-<type name=uint_fast16_t format=integral size=int16_t/>
-<type name=uint_fast32_t format=integral size=int32_t/>
-<type name=uint_fast64_t format=integral size=int64_t/>
-<type name=intptr_t format=integral size=intptr_t/>
-<type name=uintptr_t format=integral size=intptr_t/>
-<type name=intmax_t format=integral size=intmax_t/>
-<type name=uintmax_t format=integral size=intmax_t/>
-
-<!-- Standard C++ variable size types, also machine specific -->
-<type name=wchar_t format=signedIntegral size=wchar_t/>
-<type name=size_t format=integral size=size_t/>
-<type name=char format=signedIntegral size=char/>
-<type name=short format=signedIntegral size=short/>
-<type name=int format=signedIntegral size=int/>
-<type name=long format=signedIntegral size=long/>
-<type name=longlong format=signedIntegral size=longlong/>
-<type name=u_char format=signedIntegral size=char/>
-<type name=u_short format=signedIntegral size=short/>
-<type name=u_int format=signedIntegral size=int/>
-<type name=u_long format=signedIntegral size=long/>
-<type name=u_longlong format=signedIntegral size=longlong/>
-
-<!-- libc types -->
-<type name=time_t format=signedIntegral size=time_t/>
-<type name=off_t format=signedIntegral size=off_t/>
-<type name=ptrdiff_t format=signedIntegral size=ptrdiff_t/>
-<type name=dev_t format=integral size=dev_t/>
-<type name=uid_t format=integral size=uid_t/>
-<type name=gid_t format=integral size=gid_t/>
-<type name=mode_t format=integral size=mode_t/>
-<type name=nlink_t format=integral size=nlink_t/>
-<type name=pid_t format=integral size=pid_t/>
-<type name=fsid_t format=integral size=fsid_t/>
-<type name=clock_t format=integral size=clock_t/>
-<type name=id_t format=integral size=id_t/>
-<type name=key_t format=integral size=key_t/>
-<type name=blksize_t format=integral size=blksize_t/>
-
-<!-- Types within the ustl library -->
-<type name=utf8 format=integral minSize="1" maxSize="8"/>
-<type name=auto format=unstructured id="AUTO"/>
-<namespace name=ustl>
- <type name=uoff_t extends=size_t/>
- <type name=cmemlink_ptr_t format=pointer/>
- <type name=memlink_ptr_t extends=cmemlink_ptr_t/>
- <type name=memblock_ptr_t extends=memlink_ptr_t/>
- <type name=cmemlink format=struct>
- <var name=data_size type=size_t />
- <var name=data format=unstructured size=data_size />
- </type>
- <type name=memlink extends=cmemlink />
- <type name=memblock extends=cmemlink />
- <type name=string extends=memblock>
- <var name=data_size type=utf8 />
- <var name=data format=array type=utf8 size=data_size />
- </type>
-</namespace>
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ustring.cpp b/media/libdrm/mobile2/src/util/ustl-1.0/ustring.cpp
deleted file mode 100644
index db87d34..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ustring.cpp
+++ /dev/null
@@ -1,425 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ustring.cpp
-//
-// STL basic_string equivalent functionality.
-//
-
-#include "uassert.h"
-#include "ustring.h"
-#include "mistream.h"
-#include "mostream.h"
-#include "ualgo.h"
-#include <stdio.h> // for vsnprintf (in string::format)
-
-#include "uassert.h"
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-
-const uoff_t string::npos;
-const string::size_type string::size_Terminator;
-const string::value_type string::c_Terminator;
-const char string::empty_string[string::size_Terminator] = "";
-
-typedef utf8in_iterator<string::const_iterator> utf8icstring_iterator;
-typedef utf8in_iterator<string::iterator> utf8istring_iterator;
-typedef utf8out_iterator<string::iterator> utf8ostring_iterator;
-
-//----------------------------------------------------------------------
-
-/// Creates an empty string.
-string::string (void)
-: memblock ()
-{
- link (empty_string, 0U);
-}
-
-/// Assigns itself the value of string \p s
-string::string (const string& s)
-: memblock()
-{
- if (s.is_linked())
- link (s.c_str(), s.size());
- else
- assign (s);
-}
-
-/// Links to \p s
-string::string (const_pointer s)
-: memblock ()
-{
- if (!s)
- s = empty_string;
- link (s, strlen(s));
-}
-
-/// Creates a string of length \p n filled with character \p c.
-string::string (size_type n, value_type c)
-: memblock ()
-{
- resize (n);
- fill_n (begin(), n, c);
-}
-
-/// Resize the string to \p n characters. New space contents is undefined.
-void string::resize (size_type n)
-{
- memblock::resize (n);
- at(n) = c_Terminator;
-}
-
-/// Assigns itself the value of string \p s
-void string::assign (const_pointer s)
-{
- if (!s)
- s = empty_string;
- assign (s, strlen (s));
-}
-
-/// Assigns itself the value of string \p s of length \p len.
-void string::assign (const_pointer s, size_type len)
-{
- while (len && s[len - 1] == c_Terminator)
- -- len;
- resize (len);
- copy (s, len);
-}
-
-/// Appends to itself the value of string \p s of length \p len.
-void string::append (const_pointer s)
-{
- if (!s)
- s = empty_string;
- append (s, strlen (s));
-}
-
-/// Appends to itself the value of string \p s of length \p len.
-void string::append (const_pointer s, size_type len)
-{
- while (len && s[len - 1] == c_Terminator)
- -- len;
- resize (size() + len);
- copy_n (s, len, end() - len);
-}
-
-/// Appends to itself \p n characters of value \p c.
-void string::append (size_type n, value_type c)
-{
- resize (size() + n);
- fill_n (end() - n, n, c);
-}
-
-/// Copies into itself at offset \p start, the value of string \p p of length \p n.
-string::size_type string::copyto (pointer p, size_type n, const_iterator start) const
-{
- assert (p && n);
- if (!start)
- start = begin();
- const size_type btc = min(n - size_Terminator, size());
- copy_n (start, btc, p);
- p[btc] = c_Terminator;
- return (btc + size_Terminator);
-}
-
-/// Returns comparison value regarding string \p s.
-/// The return value is:
-/// \li 1 if this string is greater (by value, not length) than string \p s
-/// \li 0 if this string is equal to string \p s
-/// \li -1 if this string is less than string \p s
-///
-/*static*/ int string::compare (const_iterator first1, const_iterator last1, const_iterator first2, const_iterator last2)
-{
- assert (first1 <= last1 && (first2 <= last2 || !last2) && "Negative ranges result in memory allocation errors.");
- const size_type len1 = distance (first1, last1), len2 = distance (first2, last2);
- const int rvbylen = sign (int(len1 - len2));
- int rv = memcmp (first1, first2, min (len1, len2));
- return (rv ? rv : rvbylen);
-}
-
-/// Returns true if this string is equal to string \p s.
-bool string::operator== (const_pointer s) const
-{
- if (!s)
- s = empty_string;
- return (size() == strlen(s) && 0 == memcmp (c_str(), s, size()));
-}
-
-/// Returns the beginning of character \p i.
-string::iterator string::utf8_iat (uoff_t i)
-{
- utf8istring_iterator cfinder (begin());
- cfinder += i;
- return (cfinder.base());
-}
-
-/// Inserts wide character \p c at \p ip \p n times as a UTF-8 string.
-///
-/// \p ip is a character position, not a byte position, and must fall in
-/// the 0 through length() range.
-/// The first argument is not an iterator because it is rather difficult
-/// to get one. You'd have to use ((utf8begin() + n).base()) as the first
-/// argument, which is rather ugly. Besides, then this insert would be
-/// ambiguous with the regular character insert.
-///
-void string::insert (const uoff_t ip, wchar_t c, size_type n)
-{
- iterator ipp (utf8_iat (ip));
- ipp = iterator (memblock::insert (memblock::iterator(ipp), n * Utf8Bytes(c)));
- fill_n (utf8out (ipp), n, c);
- *end() = c_Terminator;
-}
-
-/// Inserts sequence of wide characters at \p ip.
-void string::insert (const uoff_t ip, const wchar_t* first, const wchar_t* last, const size_type n)
-{
- iterator ipp (utf8_iat (ip));
- size_type nti = distance (first, last), bti = 0;
- for (uoff_t i = 0; i < nti; ++ i)
- bti += Utf8Bytes(first[i]);
- ipp = iterator (memblock::insert (memblock::iterator(ipp), n * bti));
- utf8ostring_iterator uout (utf8out (ipp));
- for (uoff_t j = 0; j < n; ++ j)
- for (uoff_t k = 0; k < nti; ++ k, ++ uout)
- *uout = first[k];
- *end() = c_Terminator;
-}
-
-/// Inserts character \p c into this string at \p start.
-string::iterator string::insert (iterator start, const_reference c, size_type n)
-{
- start = iterator (memblock::insert (memblock::iterator(start), n));
- fill_n (start, n, c);
- *end() = c_Terminator;
- return (start);
-}
-
-/// Inserts \p count instances of string \p s at offset \p start.
-string::iterator string::insert (iterator start, const_pointer s, size_type n)
-{
- if (!s)
- s = empty_string;
- return (insert (start, s, s + strlen(s), n));
-}
-
-/// Inserts [first,last] \p n times.
-string::iterator string::insert (iterator start, const_pointer first, const_pointer last, size_type n)
-{
- assert (first <= last);
- assert (begin() <= start && end() >= start);
- assert ((first < begin() || first >= end() || size() + abs_distance(first,last) < capacity()) && "Insertion of self with autoresize is not supported");
- start = iterator (memblock::insert (memblock::iterator(start), distance(first, last) * n));
- fill (memblock::iterator(start), first, distance(first, last), n);
- *end() = c_Terminator;
- return (start);
-}
-
-/// Erases \p size bytes at \p start.
-string::iterator string::erase (iterator ep, size_type n)
-{
- string::iterator rv = memblock::erase (memblock::iterator(ep), n);
- *end() = c_Terminator;
- return (rv);
-}
-
-/// Erases \p size characters at \p start.
-/// \p start is a character position, not a byte position, and must be
-/// in the 0..length() range.
-///
-void string::erase (uoff_t ep, size_type n)
-{
- iterator first (utf8_iat(ep));
- size_t nbytes (utf8_iat(ep + n) - first);
- memblock::erase (first, nbytes);
- *end() = c_Terminator;
-}
-
-/// Replaces range [\p start, \p start + \p len] with string \p s.
-void string::replace (iterator first, iterator last, const_pointer s)
-{
- if (!s)
- s = empty_string;
- replace (first, last, s, s + strlen(s));
-}
-
-/// Replaces range [\p start, \p start + \p len] with \p count instances of string \p s.
-void string::replace (iterator first, iterator last, const_pointer i1, const_pointer i2, size_type n)
-{
- assert (first <= last);
- assert (n || distance(first, last));
- assert (first >= begin() && first <= end() && last >= first && last <= end());
- assert ((i1 < begin() || i1 >= end() || abs_distance(i1,i2) * n + size() < capacity()) && "Replacement by self can not autoresize");
- const size_type bte = distance(first, last), bti = distance(i1, i2) * n;
- if (bti < bte)
- first = iterator (memblock::erase (memblock::iterator(first), bte - bti));
- else if (bte < bti)
- first = iterator (memblock::insert (memblock::iterator(first), bti - bte));
- fill (memblock::iterator(first), i1, distance(i1, i2), n);
- *end() = c_Terminator;
-}
-
-/// Returns the offset of the first occurence of \p c after \p pos.
-uoff_t string::find (const_reference c, uoff_t pos) const
-{
- const_iterator found = ::ustl::find (iat(pos), end(), c);
- return (found < end() ? distance(begin(),found) : npos);
-}
-
-/// Returns the offset of the first occurence of substring \p s of length \p n after \p pos.
-uoff_t string::find (const string& s, uoff_t pos) const
-{
- if (s.empty() || s.size() > size() - pos)
- return (npos);
- const uoff_t endi = s.size() - 1;
- const_reference endchar = s[endi];
- uoff_t lastPos = endi;
- while (lastPos-- && s[lastPos] != endchar);
- const size_type skip = endi - lastPos;
- const_iterator i = iat(pos) + endi;
- for (; i < end() && (i = ::ustl::find (i, end(), endchar)) < end(); i += skip)
- if (memcmp (i - endi, s.c_str(), s.size()) == 0)
- return (distance (begin(), i) - endi);
- return (npos);
-}
-
-/// Returns the offset of the last occurence of character \p c before \p pos.
-uoff_t string::rfind (const_reference c, uoff_t pos) const
-{
- for (int i = min(pos,size()-1); i >= 0; --i)
- if (at(i) == c)
- return (i);
- return (npos);
-}
-
-/// Returns the offset of the last occurence of substring \p s of size \p n before \p pos.
-uoff_t string::rfind (const string& s, uoff_t pos) const
-{
- const_iterator d = iat(pos) - 1;
- const_iterator sp = begin() + s.size() - 1;
- const_iterator m = s.end() - 1;
- for (uoff_t i = 0; d > sp && i < s.size(); -- d)
- for (i = 0; i < s.size(); ++ i)
- if (m[-i] != d[-i])
- break;
- return (d > sp ? distance (begin(), d + 2 - s.size()) : npos);
-}
-
-/// Returns the offset of the first occurence of one of characters in \p s of size \p n after \p pos.
-uoff_t string::find_first_of (const string& s, uoff_t pos) const
-{
- for (uoff_t i = min(pos,size()); i < size(); ++ i)
- if (s.find (at(i)) != npos)
- return (i);
- return (npos);
-}
-
-/// Returns the offset of the first occurence of one of characters not in \p s of size \p n after \p pos.
-uoff_t string::find_first_not_of (const string& s, uoff_t pos) const
-{
- for (uoff_t i = min(pos,size()); i < size(); ++ i)
- if (s.find (at(i)) == npos)
- return (i);
- return (npos);
-}
-
-/// Returns the offset of the last occurence of one of characters in \p s of size \p n before \p pos.
-uoff_t string::find_last_of (const string& s, uoff_t pos) const
-{
- for (int i = min(pos,size()-1); i >= 0; -- i)
- if (s.find (at(i)) != npos)
- return (i);
- return (npos);
-}
-
-/// Returns the offset of the last occurence of one of characters not in \p s of size \p n before \p pos.
-uoff_t string::find_last_not_of (const string& s, uoff_t pos) const
-{
- for (int i = min(pos,size()-1); i >= 0; -- i)
- if (s.find (at(i)) == npos)
- return (i);
- return (npos);
-}
-
-/// Equivalent to a vsprintf on the string.
-int string::vformat (const char* fmt, va_list args)
-{
-#if HAVE_VA_COPY
- va_list args2;
-#else
- #define args2 args
- #undef __va_copy
- #define __va_copy(x,y)
-#endif
- size_t rv = size();
- do {
- reserve (rv);
- __va_copy (args2, args);
- rv = vsnprintf (data(), memblock::capacity(), fmt, args2);
- rv = min (rv, memblock::capacity());
- } while (rv > capacity());
- resize (min (rv, capacity()));
- return (rv);
-}
-
-/// Equivalent to a sprintf on the string.
-int string::format (const char* fmt, ...)
-{
- va_list args;
- va_start (args, fmt);
- const int rv = vformat (fmt, args);
- va_end (args);
- return (rv);
-}
-
-/// Returns the number of bytes required to write this object to a stream.
-size_t string::stream_size (void) const
-{
- return (Utf8Bytes(size()) + size());
-}
-
-/// Reads the object from stream \p os
-void string::read (istream& is)
-{
- char szbuf [8];
- is >> szbuf[0];
- size_t szsz (Utf8SequenceBytes (szbuf[0]) - 1), n = 0;
- is.verify_remaining ("read", "ustl::string", szsz);
- is.read (szbuf + 1, szsz);
- n = *utf8in(szbuf);
- is.verify_remaining ("read", "ustl::string", n);
- resize (n);
- is.read (data(), size());
-}
-
-/// Writes the object to stream \p os
-void string::write (ostream& os) const
-{
- const written_size_type sz (size());
- assert (sz == size() && "No support for writing strings larger than 4G");
-
- char szbuf [8];
- utf8out_iterator<char*> szout (szbuf);
- *szout = sz;
- size_t szsz = distance (szbuf, szout.base());
-
- os.verify_remaining ("write", "ustl::string", szsz + sz);
- os.write (szbuf, szsz);
- os.write (cdata(), sz);
-}
-
-/// Returns a hash value for [first, last)
-/*static*/ hashvalue_t string::hash (const char* first, const char* last)
-{
- hashvalue_t h = 0;
- // This has the bits flowing into each other from both sides of the number
- for (; first < last; ++ first)
- h = *first + ((h << 7) | (h >> BitsInType(hashvalue_t) - 7));
- return (h);
-}
-
-} // namespace ustl
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/ustring.h b/media/libdrm/mobile2/src/util/ustl-1.0/ustring.h
deleted file mode 100644
index 9ecf6e7..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/ustring.h
+++ /dev/null
@@ -1,263 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// ustring.h
-//
-
-#ifndef USTRING_H_1249CB7A098A9010763AAC6D37B133CF
-#define USTRING_H_1249CB7A098A9010763AAC6D37B133CF
-
-#include "memblock.h"
-#include "utf8.h"
-#include <stdarg.h> // for va_list, va_start, and va_end (in string::format)
-
-namespace ustl {
-
-/// \class string ustring.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief STL basic_string&lt;char&gt; equivalent.
-///
-/// An STL container for text string manipulation.
-/// Differences from C++ standard:
-/// - string is a class, not a template. Wide characters are assumed to be
-/// encoded with utf8 at all times except when rendering or editing,
-/// where you would use a utf8 iterator.
-/// - format member function - you can, of course use an \ref ostringstream,
-/// which also have format functions, but most of the time this way
-/// is more convenient. Because uSTL does not implement locales,
-/// format is the only way to create localized strings.
-/// - const char* cast operator. It is much clearer to use this than having
-/// to type .c_str() every time.
-/// - length returns the number of _characters_, not bytes.
-/// This function is O(N), so use wisely.
-///
-class string : public memblock {
-public:
- typedef char value_type;
- typedef value_type* pointer;
- typedef const value_type* const_pointer;
- typedef wchar_t wvalue_type;
- typedef wvalue_type* wpointer;
- typedef const wvalue_type* const_wpointer;
- typedef pointer iterator;
- typedef const_pointer const_iterator;
- typedef value_type& reference;
- typedef value_type const_reference;
- typedef ::ustl::reverse_iterator<iterator> reverse_iterator;
- typedef ::ustl::reverse_iterator<const_iterator> const_reverse_iterator;
- typedef utf8in_iterator<const_iterator> utf8_iterator;
-public:
- static const uoff_t npos = static_cast<uoff_t>(-1); ///< Value that means the end of string.
- static const value_type c_Terminator = 0; ///< String terminator
- static const size_type size_Terminator = sizeof(c_Terminator); ///< Most systems terminate strings with '\\0'
- static const char empty_string [size_Terminator]; ///< An empty string.
-public:
- string (void);
- string (const string& s);
- inline string (const string& s, uoff_t o, size_type n);
- inline explicit string (const cmemlink& l);
- string (const_pointer s);
- inline string (const_pointer s, size_type len);
- inline string (const_pointer s1, const_pointer s2);
- explicit string (size_type n, value_type c = c_Terminator);
- inline pointer data (void) { return (string::pointer (memblock::data())); }
- inline const_pointer c_str (void) const { return (string::const_pointer (memblock::cdata())); }
- inline size_type max_size (void) const { size_type s (memblock::max_size()); return (s - !!s); }
- inline size_type capacity (void) const { size_type c (memblock::capacity()); return (c - !!c); }
- void resize (size_type n);
- inline void clear (void) { resize (0); }
- inline const_iterator begin (void) const { return (const_iterator (memblock::begin())); }
- inline iterator begin (void) { return (iterator (memblock::begin())); }
- inline const_iterator end (void) const { return (const_iterator (memblock::end())); }
- inline iterator end (void) { return (iterator (memblock::end())); }
- inline const_reverse_iterator rbegin (void) const { return (const_reverse_iterator (end())); }
- inline reverse_iterator rbegin (void) { return (reverse_iterator (end())); }
- inline const_reverse_iterator rend (void) const { return (const_reverse_iterator (begin())); }
- inline reverse_iterator rend (void) { return (reverse_iterator (begin())); }
- inline utf8_iterator utf8_begin (void) const { return (utf8_iterator (begin())); }
- inline utf8_iterator utf8_end (void) const { return (utf8_iterator (end())); }
- inline const_reference at (uoff_t pos) const { assert (pos <= size() && begin()); return (begin()[pos]); }
- inline reference at (uoff_t pos) { assert (pos <= size() && begin()); return (begin()[pos]); }
- inline const_iterator iat (uoff_t pos) const { return (begin() + min (pos, size())); }
- inline iterator iat (uoff_t pos) { return (begin() + min (pos, size())); }
- inline size_type length (void) const { return (distance (utf8_begin(), utf8_end())); }
- inline void append (const_iterator i1, const_iterator i2) { append (i1, distance (i1, i2)); }
- void append (const_pointer s, size_type len);
- void append (const_pointer s);
- void append (size_type n, const_reference c);
- inline void append (size_type n, wvalue_type c) { insert (size(), c, n); }
- inline void append (const_wpointer s1, const_wpointer s2) { insert (size(), s1, s2); }
- inline void append (const_wpointer s) { const_wpointer se (s); for (;se&&*se;++se); append (s, se); }
- inline void append (const string& s) { append (s.begin(), s.end()); }
- inline void append (const string& s, uoff_t o, size_type n) { append (s.iat(o), s.iat(o+n)); }
- inline void assign (const_iterator i1, const_iterator i2) { assign (i1, distance (i1, i2)); }
- void assign (const_pointer s, size_type len);
- void assign (const_pointer s);
- inline void assign (const_wpointer s1, const_wpointer s2) { clear(); append (s1, s2); }
- inline void assign (const_wpointer s1) { clear(); append (s1); }
- inline void assign (const string& s) { assign (s.begin(), s.end()); }
- inline void assign (const string& s, uoff_t o, size_type n) { assign (s.iat(o), s.iat(o+n)); }
- size_type copyto (pointer p, size_type n, const_iterator start = NULL) const;
- inline int compare (const string& s) const { return (compare (begin(), end(), s.begin(), s.end())); }
- inline int compare (const_pointer s) const { return (compare (begin(), end(), s, s + strlen(s))); }
- static int compare (const_iterator first1, const_iterator last1, const_iterator first2, const_iterator last2);
- inline operator const value_type* (void) const;
- inline operator value_type* (void);
- inline const string& operator= (const string& s) { assign (s.begin(), s.end()); return (*this); }
- inline const string& operator= (const_reference c) { assign (&c, 1); return (*this); }
- inline const string& operator= (const_pointer s) { assign (s); return (*this); }
- inline const string& operator= (const_wpointer s) { assign (s); return (*this); }
- inline const string& operator+= (const string& s) { append (s.begin(), s.size()); return (*this); }
- inline const string& operator+= (const_reference c) { append (1, c); return (*this); }
- inline const string& operator+= (const_pointer s) { append (s); return (*this); }
- inline const string& operator+= (wvalue_type c) { append (1, c); return (*this); }
- inline const string& operator+= (const_wpointer s) { append (s); return (*this); }
- inline string operator+ (const string& s) const;
- inline bool operator== (const string& s) const { return (memblock::operator== (s)); }
- bool operator== (const_pointer s) const;
- inline bool operator== (const_reference c) const { return (size() == 1 && c == at(0)); }
- inline bool operator!= (const string& s) const { return (!operator== (s)); }
- inline bool operator!= (const_pointer s) const { return (!operator== (s)); }
- inline bool operator!= (const_reference c) const { return (!operator== (c)); }
- inline bool operator< (const string& s) const { return (0 > compare (s)); }
- inline bool operator< (const_pointer s) const { return (0 > compare (s)); }
- inline bool operator< (const_reference c) const { return (0 > compare (begin(), end(), &c, &c + 1)); }
- inline bool operator> (const_pointer s) const { return (0 < compare (s)); }
- void insert (const uoff_t ip, wvalue_type c, size_type n = 1);
- void insert (const uoff_t ip, const_wpointer first, const_wpointer last, const size_type n = 1);
- iterator insert (iterator start, const_reference c, size_type n = 1);
- iterator insert (iterator start, const_pointer s, size_type n = 1);
- iterator insert (iterator start, const_pointer first, const_iterator last, size_type n = 1);
- inline void insert (uoff_t ip, const_pointer s, size_type nlen) { insert (iat(ip), s, s + nlen); }
- inline void insert (uoff_t ip, size_type n, value_type c) { insert (iat(ip), c, n); }
- inline void insert (uoff_t ip, const string& s, uoff_t sp, size_type slen) { insert (iat(ip), s.iat(sp), s.iat(sp + slen)); }
- iterator erase (iterator start, size_type size = 1);
- void erase (uoff_t start, size_type size = 1);
- inline iterator erase (iterator first, const_iterator last) { return (erase (first, size_type(distance(first,last)))); }
- OVERLOAD_POINTER_AND_SIZE_T_V2(erase, iterator)
- inline void push_back (const_reference c) { append (1, c); }
- inline void push_back (wvalue_type c) { append (1, c); }
- inline void pop_back (void) { resize (size() - 1); }
- void replace (iterator first, iterator last, const_pointer s);
- void replace (iterator first, iterator last, const_pointer i1, const_pointer i2, size_type n = 1);
- inline void replace (iterator first, iterator last, const string& s) { replace (first, last, s.begin(), s.end()); }
- inline void replace (iterator first, iterator last, const_pointer s, size_type slen) { replace (first, last, s, s + slen); }
- inline void replace (iterator first, iterator last, size_type n, value_type c) { replace (first, last, &c, &c + 1, n); }
- inline void replace (uoff_t rp, size_type n, const string& s) { replace (iat(rp), iat(rp + n), s); }
- inline void replace (uoff_t rp, size_type n, const string& s, uoff_t sp, size_type slen) { replace (iat(rp), iat(rp + n), s.iat(sp), s.iat(sp + slen)); }
- inline void replace (uoff_t rp, size_type n, const_pointer s, size_type slen) { replace (iat(rp), iat(rp + n), s, s + slen); }
- inline void replace (uoff_t rp, size_type n, const_pointer s) { replace (iat(rp), iat(rp + n), string(s)); }
- inline void replace (uoff_t rp, size_type n, size_type count, value_type c) { replace (iat(rp), iat(rp + n), count, c); }
- inline string substr (uoff_t o, size_type n) const { return (string (*this, o, n)); }
- uoff_t find (const_reference c, uoff_t pos = 0) const;
- uoff_t find (const string& s, uoff_t pos = 0) const;
- uoff_t rfind (const_reference c, uoff_t pos = npos) const;
- uoff_t rfind (const string& s, uoff_t pos = npos) const;
- uoff_t find_first_of (const string& s, uoff_t pos = 0) const;
- uoff_t find_first_not_of (const string& s, uoff_t pos = 0) const;
- uoff_t find_last_of (const string& s, uoff_t pos = npos) const;
- uoff_t find_last_not_of (const string& s, uoff_t pos = npos) const;
- int vformat (const char* fmt, va_list args);
- int format (const char* fmt, ...) __attribute__((__format__(__printf__, 2, 3)));
- void read (istream&);
- void write (ostream& os) const;
- size_t stream_size (void) const;
- static hashvalue_t hash (const char* f1, const char* l1);
-private:
- DLL_LOCAL iterator utf8_iat (uoff_t i);
-protected:
- inline virtual size_type minimumFreeCapacity (void) const { return (size_Terminator); }
-};
-
-//----------------------------------------------------------------------
-
-/// Assigns itself the value of string \p s
-inline string::string (const cmemlink& s)
-: memblock ()
-{
- assign (const_iterator (s.begin()), s.size());
-}
-
-/// Assigns itself a [o,o+n) substring of \p s.
-inline string::string (const string& s, uoff_t o, size_type n)
-: memblock()
-{
- assign (s, o, n);
-}
-
-/// Copies the value of \p s of length \p len into itself.
-inline string::string (const_pointer s, size_type len)
-: memblock ()
-{
- assign (s, len);
-}
-
-/// Copies into itself the string data between \p s1 and \p s2
-inline string::string (const_pointer s1, const_pointer s2)
-: memblock ()
-{
- assert (s1 <= s2 && "Negative ranges result in memory allocation errors.");
- assign (s1, s2);
-}
-
-/// Returns the pointer to the first character.
-inline string::operator const string::value_type* (void) const
-{
- assert ((!end() || *end() == c_Terminator) && "This string is linked to data that is not 0-terminated. This may cause serious security problems. Please assign the data instead of linking.");
- return (begin());
-}
-
-/// Returns the pointer to the first character.
-inline string::operator string::value_type* (void)
-{
- assert ((end() && *end() == c_Terminator) && "This string is linked to data that is not 0-terminated. This may cause serious security problems. Please assign the data instead of linking.");
- return (begin());
-}
-
-/// Concatenates itself with \p s
-inline string string::operator+ (const string& s) const
-{
- string result (*this);
- result += s;
- return (result);
-}
-
-//----------------------------------------------------------------------
-// Operators needed to avoid comparing pointer to pointer
-
-#define PTR_STRING_CMP(op, impl) \
-inline bool op (const char* s1, const string& s2) { return impl; }
-PTR_STRING_CMP (operator==, (s2 == s1))
-PTR_STRING_CMP (operator!=, (s2 != s1))
-PTR_STRING_CMP (operator<, (s2 > s1))
-PTR_STRING_CMP (operator<=, (s2 >= s1))
-PTR_STRING_CMP (operator>, (s2 < s1))
-PTR_STRING_CMP (operator>=, (s2 <= s1))
-#undef PTR_STRING_CMP
-
-//----------------------------------------------------------------------
-
-template <typename T>
-inline hashvalue_t hash_value (const T& v)
-{ return (string::hash (v.begin(), v.end())); }
-
-template <>
-inline hashvalue_t hash_value (const string::const_pointer& v)
-{ return (string::hash (v, v + strlen(v))); }
-
-template <>
-inline hashvalue_t hash_value (const string::pointer& v)
-{ return (string::hash (v, v + strlen(v))); }
-
-//----------------------------------------------------------------------
-
-} // namespace ustl
-
-// Specialization for stream alignment
-ALIGNOF (ustl::string, alignof (string::value_type()))
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/utf8.h b/media/libdrm/mobile2/src/util/ustl-1.0/utf8.h
deleted file mode 100644
index f829e7d..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/utf8.h
+++ /dev/null
@@ -1,200 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// utf8.h
-//
-// This file contains stream iterators that read and write UTF-8 encoded
-// characters. The encoding is defined as follows:
-//
-// U-00000000 - U-0000007F: 0xxxxxxx
-// U-00000080 - U-000007FF: 110xxxxx 10xxxxxx
-// U-00000800 - U-0000FFFF: 1110xxxx 10xxxxxx 10xxxxxx
-// U-00010000 - U-001FFFFF: 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
-// U-00200000 - U-03FFFFFF: 111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
-// U-04000000 - U-7FFFFFFF: 1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
-// U-80000000 - U-FFFFFFFF: 11111110 100000xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
-//
-// The last range in not in the UTF-8 standard because Unicode forbids
-// characters of those values. However, since ustl::string uses this code
-// to write its length, the support is here. The reason it was put here
-// in the first place, is that extra code would have been necessary to
-// flag that range as invalid.
-//
-#ifndef UTF8_H_3D7AEEEB3A88928D4D280B785F78B6F4
-#define UTF8_H_3D7AEEEB3A88928D4D280B785F78B6F4
-
-#include "uiterator.h"
-
-namespace ustl {
-
-//----------------------------------------------------------------------
-
-typedef uint8_t utf8subchar_t; ///< Type for the encoding subcharacters.
-
-//----------------------------------------------------------------------
-
-/// Returns the number of bytes required to UTF-8 encode \p v.
-inline size_t Utf8Bytes (wchar_t v)
-{
- static const uint32_t c_Bounds[] = { 0x0000007F, 0x000007FF, 0x0000FFFF, 0x001FFFFF, 0x03FFFFFF, 0x7FFFFFFF, 0xFFFFFFFF, };
- size_t bi = 0;
- while (c_Bounds[bi++] < uint32_t(v));
- return (bi);
-}
-
-/// Returns the number of bytes in a UTF-8 sequence that starts with \p c.
-inline size_t Utf8SequenceBytes (wchar_t c) // a wchar_t to keep c in a full register
-{
- // Count the leading bits. Header bits are 1 * nBytes followed by a 0.
- // 0 - single byte character. Take 7 bits (0xFF >> 1)
- // 1 - error, in the middle of the character. Take 6 bits (0xFF >> 2)
- // so you will keep reading invalid entries until you hit the next character.
- // >2 - multibyte character. Take remaining bits, and get the next bytes.
- // All errors are ignored, since the user can not correct them.
- //
- wchar_t mask = 0x80;
- size_t nBytes = 0;
- for (; c & mask; ++nBytes)
- mask >>= 1;
- return (nBytes ? nBytes : 1); // A sequence is always at least 1 byte.
-}
-
-//----------------------------------------------------------------------
-
-/// \class utf8in_iterator utf8.h ustl.h
-/// \ingroup IteratorAdaptors
-///
-/// \brief An iterator adaptor to character containers for reading UTF-8 encoded text.
-///
-/// For example, you can copy from ustl::string to ustl::vector<wchar_t> with
-/// copy (utf8in (str.begin()), utf8in (str.end()), back_inserter(wvect));
-/// There is no error handling; if the reading frame slips you'll get extra
-/// characters, one for every misaligned byte. Although it is possible to skip
-/// to the start of the next character, that would result in omitting the
-/// misformatted character and the one after it, making it very difficult to
-/// detect by the user. It is better to write some strange characters and let
-/// the user know his file is corrupted. Another problem is overflow on bad
-/// encodings (like a 0xFF on the end of a string). This is checked through
-/// the end-of-string nul character, which will always be there as long as
-/// you are using the string class.
-///
-template <typename Iterator, typename WChar = wchar_t>
-class utf8in_iterator {
-public:
- typedef typename iterator_traits<Iterator>::value_type value_type;
- typedef typename iterator_traits<Iterator>::difference_type difference_type;
- typedef typename iterator_traits<Iterator>::pointer pointer;
- typedef typename iterator_traits<Iterator>::reference reference;
-public:
- explicit utf8in_iterator (const Iterator& is) : m_i (is), m_v (0) { Read(); }
- utf8in_iterator (const utf8in_iterator& i) : m_i (i.m_i), m_v (i.m_v) {}
- inline const utf8in_iterator& operator= (const utf8in_iterator& i) { m_i = i.m_i; m_v = i.m_v; return (*this); }
- inline Iterator base (void) const { return (m_i - (Utf8Bytes(m_v) - 1)); }
- /// Reads and returns the next value.
- inline WChar operator* (void) const { return (m_v); }
- inline utf8in_iterator& operator++ (void) { ++m_i; Read(); return (*this); }
- inline utf8in_iterator operator++ (int) { utf8in_iterator old (*this); operator++(); return (old); }
- inline utf8in_iterator& operator+= (uoff_t n) { while (n--) operator++(); return (*this); }
- inline utf8in_iterator operator+ (uoff_t n) { utf8in_iterator v (*this); return (v += n); }
- inline bool operator== (const utf8in_iterator& i) const { return (m_i == i.m_i); }
- inline bool operator< (const utf8in_iterator& i) const { return (m_i < i.m_i); }
- difference_type operator- (const utf8in_iterator& i) const;
-private:
- void Read (void);
-private:
- Iterator m_i;
- WChar m_v;
-};
-
-/// Steps to the next character and updates current returnable value.
-template <typename Iterator, typename WChar>
-void utf8in_iterator<Iterator,WChar>::Read (void)
-{
- const utf8subchar_t c = *m_i;
- size_t nBytes = Utf8SequenceBytes (c);
- m_v = c & (0xFF >> nBytes); // First byte contains bits after the header.
- while (--nBytes && *++m_i) // Each subsequent byte has 6 bits.
- m_v = (m_v << 6) | (*m_i & 0x3F);
-}
-
-/// Returns the distance in characters (as opposed to the distance in bytes).
-template <typename Iterator, typename WChar>
-typename utf8in_iterator<Iterator,WChar>::difference_type
-utf8in_iterator<Iterator,WChar>::operator- (const utf8in_iterator<Iterator,WChar>& last) const
-{
- difference_type dist = 0;
- for (Iterator first (last.m_i); first < m_i; ++dist)
- first = advance (first, Utf8SequenceBytes (*first));
- return (dist);
-}
-
-//----------------------------------------------------------------------
-
-/// \class utf8out_iterator utf8.h ustl.h
-/// \ingroup IteratorAdaptors
-///
-/// \brief An iterator adaptor to character containers for writing UTF-8 encoded text.
-///
-template <typename Iterator, typename WChar = wchar_t>
-class utf8out_iterator {
-public:
- typedef typename iterator_traits<Iterator>::value_type value_type;
- typedef typename iterator_traits<Iterator>::difference_type difference_type;
- typedef typename iterator_traits<Iterator>::pointer pointer;
- typedef typename iterator_traits<Iterator>::reference reference;
-public:
- explicit utf8out_iterator (const Iterator& os) : m_i (os) {}
- utf8out_iterator (const utf8out_iterator& i) : m_i (i.m_i) {}
- inline const Iterator& base (void) const { return (m_i); }
- /// Writes \p v into the stream.
- utf8out_iterator& operator= (WChar v);
- inline utf8out_iterator& operator* (void) { return (*this); }
- inline utf8out_iterator& operator++ (void) { return (*this); }
- inline utf8out_iterator operator++ (int) { return (*this); }
- inline bool operator== (const utf8out_iterator& i) const { return (m_i == i.m_i); }
- inline bool operator< (const utf8out_iterator& i) const { return (m_i < i.m_i); }
-private:
- Iterator m_i;
-};
-
-/// Writes \p v into the stream.
-template <typename Iterator, typename WChar>
-utf8out_iterator<Iterator,WChar>& utf8out_iterator<Iterator,WChar>::operator= (WChar v)
-{
- const size_t nBytes = Utf8Bytes (v);
- if (nBytes > 1) {
- // Write the bits 6 bits at a time, except for the first one,
- // which may be less than 6 bits.
- register wchar_t shift = nBytes * 6;
- *m_i++ = ((v >> (shift -= 6)) & 0x3F) | (0xFF << (8 - nBytes));
- while (shift)
- *m_i++ = ((v >> (shift -= 6)) & 0x3F) | 0x80;
- } else // If only one byte, there is no header.
- *m_i++ = v;
- return (*this);
-}
-
-//----------------------------------------------------------------------
-
-/// Returns a UTF-8 adaptor writing to \p i. Useful in conjuction with back_insert_iterator.
-template <typename Iterator>
-inline utf8out_iterator<Iterator> utf8out (Iterator i)
-{
- return (utf8out_iterator<Iterator> (i));
-}
-
-/// Returns a UTF-8 adaptor reading from \p i.
-template <typename Iterator>
-inline utf8in_iterator<Iterator> utf8in (Iterator i)
-{
- return (utf8in_iterator<Iterator> (i));
-}
-
-//----------------------------------------------------------------------
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/utuple.h b/media/libdrm/mobile2/src/util/ustl-1.0/utuple.h
deleted file mode 100644
index 8a003ab..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/utuple.h
+++ /dev/null
@@ -1,247 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// utuple.h
-//
-
-#ifndef UTUPLE_H_7324ADEC49B397CA74A56F6050FD5A6B
-#define UTUPLE_H_7324ADEC49B397CA74A56F6050FD5A6B
-
-#include "ualgo.h"
-
-#if PLATFORM_ANDROID
-#undef CPU_HAS_MMX
-#endif
-
-namespace ustl {
-
-/// \class tuple utuple.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief A fixed-size array of \p N \p Ts.
-///
-template <size_t N, typename T>
-class tuple {
-public:
- typedef T value_type;
- typedef size_t size_type;
- typedef value_type* pointer;
- typedef const value_type* const_pointer;
- typedef value_type& reference;
- typedef const value_type& const_reference;
- typedef pointer iterator;
- typedef const_pointer const_iterator;
- typedef ::ustl::reverse_iterator<iterator> reverse_iterator;
- typedef ::ustl::reverse_iterator<const_iterator> const_reverse_iterator;
- typedef pair<iterator,iterator> range_t;
- typedef pair<const_iterator,const_iterator> const_range_t;
-public:
- template <typename T2>
- inline tuple (const tuple<N,T2>& t);
- inline tuple (const tuple<N,T>& t);
- inline tuple (const_pointer v);
- inline tuple (void) { for (uoff_t i = 0; i < N; ++ i) m_v[i] = T(); }
- explicit inline tuple (const_reference v0, const_reference v1 = T(), const_reference v2 = T(), const_reference v3 = T());
- inline iterator begin (void) { return (m_v); }
- inline const_iterator begin (void) const { return (m_v); }
- inline iterator end (void) { return (begin() + N); }
- inline const_iterator end (void) const { return (begin() + N); }
- inline size_type size (void) const { return (N); }
- inline size_type max_size (void) const { return (N); }
- inline bool empty (void) const { return (N == 0); }
- inline const_reference at (size_type i) const { return (m_v[i]); }
- inline reference at (size_type i) { return (m_v[i]); }
- inline const_reference operator[] (size_type i) const { return (m_v[i]); }
- inline reference operator[] (size_type i) { return (m_v[i]); }
- template <typename T2>
- inline const tuple& operator= (const tuple<N,T2>& src);
- inline const tuple& operator= (const tuple<N,T>& src);
- inline const tuple& operator+= (const_reference v)
- { for (uoff_t i = 0; i < N; ++ i) m_v[i] += v; return (*this); }
- inline const tuple& operator-= (const_reference v)
- { for (uoff_t i = 0; i < N; ++ i) m_v[i] -= v; return (*this); }
- inline const tuple& operator*= (const_reference v)
- { for (uoff_t i = 0; i < N; ++ i) m_v[i] *= v; return (*this); }
- inline const tuple& operator/= (const_reference v)
- { for (uoff_t i = 0; i < N; ++ i) m_v[i] /= v; return (*this); }
- inline const tuple operator+ (const_reference v) const
- { tuple result; for (uoff_t i = 0; i < N; ++ i) result[i] = m_v[i] + v; return (result); }
- inline const tuple operator- (const_reference v) const
- { tuple result; for (uoff_t i = 0; i < N; ++ i) result[i] = m_v[i] - v; return (result); }
- inline const tuple operator* (const_reference v) const
- { tuple result; for (uoff_t i = 0; i < N; ++ i) result[i] = m_v[i] * v; return (result); }
- inline const tuple operator/ (const_reference v) const
- { tuple result; for (uoff_t i = 0; i < N; ++ i) result[i] = m_v[i] / v; return (result); }
- inline void swap (tuple<N,T>& v)
- { for (uoff_t i = 0; i < N; ++ i) ::ustl::swap (m_v[i], v.m_v[i]); }
-private:
- T m_v [N];
-};
-
-} // namespace ustl
-
-#include "simd.h"
-
-namespace ustl {
-
-template <size_t N, typename T>
-template <typename T2>
-inline tuple<N,T>::tuple (const tuple<N,T2>& t)
-{ simd::pconvert (t, *this, simd::fcast<T2,T>()); }
-
-template <size_t N, typename T>
-inline tuple<N,T>::tuple (const tuple<N,T>& t)
-{ simd::passign (t, *this); }
-
-template <size_t N, typename T>
-inline tuple<N,T>::tuple (const_pointer v)
-{ simd::ipassign (v, *this); }
-
-template <size_t N, typename T>
-inline tuple<N,T>::tuple (const_reference v0, const_reference v1, const_reference v2, const_reference v3)
-{
- m_v[0] = v0;
- if (N > 1) m_v[1] = v1;
- if (N > 2) m_v[2] = v2;
- if (N > 3) m_v[3] = v3;
- if (N > 4) fill_n (m_v + 4, N - 4, T());
-}
-
-template <size_t N, typename T>
-template <typename T2>
-inline const tuple<N,T>& tuple<N,T>::operator= (const tuple<N,T2>& src)
-{ simd::pconvert (src, *this, simd::fcast<T2,T>()); return (*this); }
-
-template <size_t N, typename T>
-inline const tuple<N,T>& tuple<N,T>::operator= (const tuple<N,T>& src)
-{ simd::passign (src, *this); return (*this); }
-
-template <size_t N, typename T1, typename T2>
-inline bool operator== (const tuple<N,T1>& t1, const tuple<N,T2>& t2)
-{
- for (uoff_t i = 0; i < N; ++ i)
- if (t1[i] != t2[i])
- return (false);
- return (true);
-}
-
-template <size_t N, typename T1, typename T2>
-inline bool operator< (const tuple<N,T1>& t1, const tuple<N,T2>& t2)
-{
- for (uoff_t i = 0; i < N && t1[i] <= t2[i]; ++ i)
- if (t1[i] < t2[i])
- return (true);
- return (false);
-}
-
-template <size_t N, typename T1, typename T2>
-inline const tuple<N,T1>& operator+= (tuple<N,T1>& t1, const tuple<N,T2>& t2)
- { for (uoff_t i = 0; i < N; ++ i) t1[i] = T1(t1[i] + t2[i]); return (t1); }
-
-template <size_t N, typename T1, typename T2>
-inline const tuple<N,T1>& operator-= (tuple<N,T1>& t1, const tuple<N,T2>& t2)
- { for (uoff_t i = 0; i < N; ++ i) t1[i] = T1(t1[i] - t2[i]); return (t1); }
-
-template <size_t N, typename T1, typename T2>
-inline const tuple<N,T1>& operator*= (tuple<N,T1>& t1, const tuple<N,T2>& t2)
- { for (uoff_t i = 0; i < N; ++ i) t1[i] = T1(t1[i] * t2[i]); return (t1); }
-
-template <size_t N, typename T1, typename T2>
-inline const tuple<N,T1>& operator/= (tuple<N,T1>& t1, const tuple<N,T2>& t2)
- { for (uoff_t i = 0; i < N; ++ i) t1[i] = T1(t1[i] / t2[i]); return (t1); }
-
-template <size_t N, typename T1, typename T2>
-inline const tuple<N,T1> operator+ (const tuple<N,T1>& t1, const tuple<N,T2>& t2)
-{
- tuple<N,T1> result;
- for (uoff_t i = 0; i < N; ++ i) result[i] = T1(t1[i] + t2[i]);
- return (result);
-}
-
-template <size_t N, typename T1, typename T2>
-inline const tuple<N,T1> operator- (const tuple<N,T1>& t1, const tuple<N,T2>& t2)
-{
- tuple<N,T1> result;
- for (uoff_t i = 0; i < N; ++ i) result[i] = T1(t1[i] - t2[i]);
- return (result);
-}
-
-template <size_t N, typename T1, typename T2>
-inline const tuple<N,T1> operator* (const tuple<N,T1>& t1, const tuple<N,T2>& t2)
-{
- tuple<N,T1> result;
- for (uoff_t i = 0; i < N; ++ i) result[i] = T1(t1[i] * t2[i]);
- return (result);
-}
-
-template <size_t N, typename T1, typename T2>
-inline const tuple<N,T1> operator/ (const tuple<N,T1>& t1, const tuple<N,T2>& t2)
-{
- tuple<N,T1> result;
- for (uoff_t i = 0; i < N; ++ i) result[i] = T1(t1[i] / t2[i]);
- return (result);
-}
-
-#if CPU_HAS_SSE
-#define SSE_TUPLE_SPECS(n,type) \
-template <> inline tuple<n,type>::tuple (void) \
-{ asm ("xorps %%xmm0, %%xmm0\n\tmovups %%xmm0, %0"::"m"(m_v[0]):"xmm0","memory"); } \
-template<> inline void tuple<n,type>::swap (tuple<n,type>& v) \
-{ asm ("movups %0,%%xmm0\n\tmovups %1,%%xmm1\n\tmovups %%xmm0,%1\n\tmovups %%xmm1,%0"::"m"(m_v[0]),"m"(v.m_v[0]):"xmm0","xmm1","memory"); }
-SSE_TUPLE_SPECS(4,float)
-SSE_TUPLE_SPECS(4,int32_t)
-SSE_TUPLE_SPECS(4,uint32_t)
-#undef SSE_TUPLE_SPECS
-#endif
-#if CPU_HAS_MMX
-#define MMX_TUPLE_SPECS(n,type) \
-template <> inline tuple<n,type>::tuple (void) \
-{ asm ("pxor %%mm0, %%mm0\n\tmovq %%mm0, %0"::"m"(m_v[0]):"mm0","memory"); simd::reset_mmx(); } \
-template<> inline void tuple<n,type>::swap (tuple<n,type>& v) \
-{ asm ("movq %0,%%mm0\n\tmovq %1,%%mm1\n\tmovq %%mm0,%1\n\tmovq %%mm1,%0"::"m"(m_v[0]),"m"(v.m_v[0]):"mm0","mm1","memory"); simd::reset_mmx(); }
-MMX_TUPLE_SPECS(2,float)
-MMX_TUPLE_SPECS(4,int16_t)
-MMX_TUPLE_SPECS(4,uint16_t)
-MMX_TUPLE_SPECS(2,int32_t)
-MMX_TUPLE_SPECS(2,uint32_t)
-MMX_TUPLE_SPECS(8,int8_t)
-MMX_TUPLE_SPECS(8,uint8_t)
-#undef MMX_TUPLE_SPECS
-#endif
-
-#define SIMD_TUPLE_PACKOP(N,T) \
-template <> inline const tuple<N,T>& operator+= (tuple<N,T>& t1, const tuple<N,T>& t2) \
- { simd::padd (t2, t1); return (t1); } \
-template <> inline const tuple<N,T>& operator-= (tuple<N,T>& t1, const tuple<N,T>& t2) \
- { simd::psub (t2, t1); return (t1); } \
-template <> inline const tuple<N,T>& operator*= (tuple<N,T>& t1, const tuple<N,T>& t2) \
- { simd::pmul (t2, t1); return (t1); } \
-template <> inline const tuple<N,T>& operator/= (tuple<N,T>& t1, const tuple<N,T>& t2) \
- { simd::pdiv (t2, t1); return (t1); } \
-template <> inline const tuple<N,T> operator+ (const tuple<N,T>& t1, const tuple<N,T>& t2) \
- { tuple<N,T> result (t1); simd::padd (t2, result); return (result); } \
-template <> inline const tuple<N,T> operator- (const tuple<N,T>& t1, const tuple<N,T>& t2) \
- { tuple<N,T> result (t1); simd::psub (t2, result); return (result); } \
-template <> inline const tuple<N,T> operator* (const tuple<N,T>& t1, const tuple<N,T>& t2) \
- { tuple<N,T> result (t1); simd::pmul (t2, result); return (result); } \
-template <> inline const tuple<N,T> operator/ (const tuple<N,T>& t1, const tuple<N,T>& t2) \
- { tuple<N,T> result (t1); simd::pdiv (t2, result); return (result); }
-SIMD_TUPLE_PACKOP(4,float)
-SIMD_TUPLE_PACKOP(2,float)
-SIMD_TUPLE_PACKOP(2,double)
-SIMD_TUPLE_PACKOP(4,int32_t)
-SIMD_TUPLE_PACKOP(4,uint32_t)
-SIMD_TUPLE_PACKOP(4,int16_t)
-SIMD_TUPLE_PACKOP(4,uint16_t)
-SIMD_TUPLE_PACKOP(2,int32_t)
-SIMD_TUPLE_PACKOP(2,uint32_t)
-SIMD_TUPLE_PACKOP(8,int8_t)
-SIMD_TUPLE_PACKOP(8,uint8_t)
-#undef SIMD_TUPLE_PACKOP
-
-} // namespace ustl
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/utypes.h b/media/libdrm/mobile2/src/util/ustl-1.0/utypes.h
deleted file mode 100644
index f0b0265..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/utypes.h
+++ /dev/null
@@ -1,69 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// utypes.h
-//
-// Types used by this library.
-//
-
-#ifndef UTYPES_H_118BBB3B50B7DBF22F5460C52E515C83
-#define UTYPES_H_118BBB3B50B7DBF22F5460C52E515C83
-
-#include "config.h"
-#ifndef STDC_HEADERS
- #error This library requires standard C and C++ headers to compile.
-#endif
-#ifndef STDUNIX_HEADERS
- #error This library compiles only on UNIX systems.
-#endif
-#define __STDC_LIMIT_MACROS // For WCHAR_MIN and WCHAR_MAX in stdint.
-#define __STDC_CONSTANT_MACROS // For UINT??_C macros to avoid using L and UL suffixes on constants.
-#ifdef HAVE_STDINT_H
- #include <stdint.h>
-#elif HAVE_INTTYPES_H
- #include <inttypes.h>
-#else
- #error Need standard integer types definitions, usually in stdint.h
-#endif
-#include <stddef.h> // For ptrdiff_t, size_t
-#include <limits.h>
-#include <float.h>
-#ifdef HAVE_SYS_TYPES_H
- #include <sys/types.h>
-#endif
-#ifndef SIZE_MAX
- #define SIZE_MAX UINT_MAX
-#endif
-#if sun || __sun // Solaris defines UINTPTR_MAX as empty.
- #undef UINTPTR_MAX
- #define UINTPTR_MAX ULONG_MAX
-#endif
-#ifndef WCHAR_MAX
- #ifdef __WCHAR_MAX__
- #define WCHAR_MAX __WCHAR_MAX__
- #else
- #define WCHAR_MAX CHAR_MAX
- #endif
-#endif
-#ifdef HAVE_LONG_LONG
- #ifndef LLONG_MAX
- #define ULLONG_MAX UINT64_C(0xFFFFFFFFFFFFFFFF)
- #define LLONG_MAX INT64_C(0x7FFFFFFFFFFFFFFF)
- #define LLONG_MIN ULLONG_MAX
- #endif
-#endif
-#if !PLATFORM_ANDROID
-#ifndef BYTE_ORDER
- #define LITTLE_ENDIAN USTL_LITTLE_ENDIAN
- #define BIG_ENDIAN USTL_BIG_ENDIAN
- #define BYTE_ORDER USTL_BYTE_ORDER
-#endif
-#endif
-
-typedef size_t uoff_t; ///< A type for storing offsets into blocks measured by size_t.
-typedef uint32_t hashvalue_t; ///< Value type returned by the hash functions.
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uutility.h b/media/libdrm/mobile2/src/util/ustl-1.0/uutility.h
deleted file mode 100644
index 7b5ae64..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uutility.h
+++ /dev/null
@@ -1,387 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-/// \file uutility.h
-///
-/// \brief Utility templates.
-///
-/// Everything in here except min(), max(), distance(), and advance()
-/// are uSTL extensions and are absent from other STL implementations.
-///
-
-#ifndef UUTILITY_H_6A58BD296269A82A4AAAA4FD19FDB3AC
-#define UUTILITY_H_6A58BD296269A82A4AAAA4FD19FDB3AC
-
-#include "uassert.h"
-#include "utypes.h"
-
-#if PLATFORM_ANDROID
-#include <stdio.h>
-#undef CPU_HAS_MMX
-#endif
-
-namespace ustl {
-
-#ifdef __GNUC__
- /// Returns the number of elements in a static vector
- #define VectorSize(v) (sizeof(v) / sizeof(*v))
-#else
- // Old compilers will not be able to evaluate *v on an empty vector.
- // The tradeoff here is that VectorSize will not be able to measure arrays of local structs.
- #define VectorSize(v) (sizeof(v) / ustl::size_of_elements(1, v))
-#endif
-
-/// Expands into a ptr,size expression for the given static vector; useful as link arguments.
-#define VectorBlock(v) (v)+0, VectorSize(v) // +0 makes it work under gcc 2.95
-/// Expands into a begin,end expression for the given static vector; useful for algorithm arguments.
-#define VectorRange(v) VectorBlock(v)+(v)
-
-/// Returns the number of bits in the given type
-#define BitsInType(t) (sizeof(t) * CHAR_BIT)
-
-/// Returns the mask of type \p t with the lowest \p n bits set.
-#define BitMask(t,n) (t(~t(0)) >> ((sizeof(t) * CHAR_BIT) - (n)))
-
-/// Argument that is used only in debug builds (as in an assert)
-#ifndef NDEBUG
- #define DebugArg(x) x
-#else
- #define DebugArg(x)
-#endif
-
-/// Shorthand for container iteration.
-#define foreach(type,i,ctr) for (type i = (ctr).begin(); i != (ctr).end(); ++ i)
-/// Shorthand for container reverse iteration.
-#define eachfor(type,i,ctr) for (type i = (ctr).rbegin(); i != (ctr).rend(); ++ i)
-
-/// Macro for passing template types as macro arguments.
-/// \@{
-#define TEMPLATE_FULL_DECL1(d1,t1) template <d1 t1>
-#define TEMPLATE_FULL_DECL2(d1,t1,d2,t2) template <d1 t1, d2 t2>
-#define TEMPLATE_FULL_DECL3(d1,t1,d2,t2,d3,t3) template <d1 t1, d2 t2, d3 t3>
-#define TEMPLATE_DECL1(t1) TEMPLATE_FULL_DECL1(typename,t1)
-#define TEMPLATE_DECL2(t1,t2) TEMPLATE_FULL_DECL2(typename,t1,typename,t2)
-#define TEMPLATE_DECL3(t1,t2,t3) TEMPLATE_FULL_DECL3(typename,t1,typename,t2,typename,t3)
-#define TEMPLATE_TYPE1(type,a1) type<a1>
-#define TEMPLATE_TYPE2(type,a1,a2) type<a1,a2>
-#define TEMPLATE_TYPE3(type,a1,a2,a3) type<a1,a2,a3>
-/// \@}
-
-/// Returns the minimum of \p a and \p b
-template <typename T1, typename T2>
-inline const T1 min (const T1& a, const T2& b)
-{
- return (a < b ? a : b);
-}
-
-/// Returns the maximum of \p a and \p b
-template <typename T1, typename T2>
-inline const T1 max (const T1& a, const T2& b)
-{
- return (b < a ? a : b);
-}
-
-/// \brief Divides \p n1 by \p n2 and rounds the result up.
-/// This is in contrast to regular division, which rounds down.
-/// Negative numbers are rounded down because they are an unusual case, supporting
-/// which would require a branch. Since this is frequently used in graphics, the
-/// speed is important.
-///
-template <typename T1, typename T2>
-inline T1 DivRU (T1 n1, T2 n2)
-{
- return (n1 / n2 + (n1 % n2 > 0));
-}
-
-/// The alignment performed by default.
-const size_t c_DefaultAlignment = __alignof__(void*);
-
-/// \brief Rounds \p n up to be divisible by \p grain
-template <typename T>
-inline T Align (T n, size_t grain = c_DefaultAlignment)
-{
- T a, r = n % grain;
- if (grain == 2) return (n + r);
- switch (grain) {
- case 4: case 8: case 16: a = (n & ~(grain - 1)) + grain; break;
- default: a = n + (grain - r);
- };
- return (r ? a : n);
-}
-
-/// Offsets an iterator
-template <typename T>
-inline T advance (T i, ssize_t offset)
-{
- return (i + offset);
-}
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-/// Offsets a void pointer
-template <>
-inline const void* advance (const void* p, ssize_t offset)
-{
- assert (p || !offset);
- return (reinterpret_cast<const uint8_t*>(p) + offset);
-}
-
-/// Offsets a void pointer
-template <>
-inline void* advance (void* p, ssize_t offset)
-{
- assert (p || !offset);
- return (reinterpret_cast<uint8_t*>(p) + offset);
-}
-#endif
-
-/// Returns the difference \p p1 - \p p2
-template <typename T1, typename T2>
-inline ptrdiff_t distance (T1 i1, T2 i2)
-{
- return (i2 - i1);
-}
-
-#ifndef DOXYGEN_SHOULD_SKIP_THIS
-#define UNVOID_DISTANCE(T1const,T2const) \
-template <> inline ptrdiff_t distance (T1const void* p1, T2const void* p2) \
-{ return ((T2const uint8_t*)(p2) - (T1const uint8_t*)(p1)); }
-UNVOID_DISTANCE(,)
-UNVOID_DISTANCE(const,const)
-UNVOID_DISTANCE(,const)
-UNVOID_DISTANCE(const,)
-#undef UNVOID_DISTANCE
-#endif
-
-/// \brief Returns the absolute value of \p v
-/// Unlike the stdlib functions, this is inline and works with all types.
-template <typename T>
-inline T absv (T v)
-{
- return (v < 0 ? -v : v);
-}
-
-/// \brief Returns -1 for negative values, 1 for positive, and 0 for 0
-template <typename T>
-inline T sign (T v)
-{
- return ((0 < v) - (v < 0));
-}
-
-/// Returns the absolute value of the distance i1 and i2
-template <typename T1, typename T2>
-inline size_t abs_distance (T1 i1, T2 i2)
-{
- return (absv (distance(i1, i2)));
-}
-
-/// Returns the size of \p n elements of size \p T
-template <typename T>
-inline size_t size_of_elements (size_t n, const T*)
-{
- return (n * sizeof(T));
-}
-
-// Defined in byteswap.h, which is usually unusable.
-#undef bswap_16
-#undef bswap_32
-#undef bswap_64
-
-#if CPU_HAS_CMPXCHG8 // If it has that, it has bswap.
-inline uint16_t bswap_16 (uint16_t v) { asm ("rorw $8, %w0" : "=r"(v) : "0"(v) : "cc"); return (v); }
-inline uint32_t bswap_32 (uint32_t v) { asm ("bswap %0" : "=r"(v) : "0"(v)); return (v); }
-#else
-inline uint16_t bswap_16 (uint16_t v) { return (v << 8 | v >> 8); }
-inline uint32_t bswap_32 (uint32_t v) { return (v << 24 | (v & 0xFF00) << 8 | (v >> 8) & 0xFF00 | v >> 24); }
-#endif
-#if HAVE_INT64_T
-inline uint64_t bswap_64 (uint64_t v) { return ((uint64_t(bswap_32(v)) << 32) | bswap_32(v >> 32)); }
-#endif
-
-/// \brief Swaps the byteorder of \p v.
-template <typename T>
-inline T bswap (const T& v)
-{
- switch (BitsInType(T)) {
- default: return (v);
- case 16: return (T (bswap_16 (uint16_t (v))));
- case 32: return (T (bswap_32 (uint32_t (v))));
-#if HAVE_INT64_T
- case 64: return (T (bswap_64 (uint64_t (v))));
-#endif
- };
-}
-
-#if USTL_BYTE_ORDER == USTL_BIG_ENDIAN
-template <typename T> inline T le_to_native (const T& v) { return (bswap (v)); }
-template <typename T> inline T be_to_native (const T& v) { return (v); }
-template <typename T> inline T native_to_le (const T& v) { return (bswap (v)); }
-template <typename T> inline T native_to_be (const T& v) { return (v); }
-#elif USTL_BYTE_ORDER == USTL_LITTLE_ENDIAN
-template <typename T> inline T le_to_native (const T& v) { return (v); }
-template <typename T> inline T be_to_native (const T& v) { return (bswap (v)); }
-template <typename T> inline T native_to_le (const T& v) { return (v); }
-template <typename T> inline T native_to_be (const T& v) { return (bswap (v)); }
-#endif // USTL_BYTE_ORDER
-
-/// Deletes \p p and sets it to NULL
-template <typename T>
-inline void Delete (T*& p)
-{
- delete p;
- p = NULL;
-}
-
-/// Deletes \p p as an array and sets it to NULL
-template <typename T>
-inline void DeleteVector (T*& p)
-{
- delete [] p;
- p = NULL;
-}
-
-/// Template of making != from ! and ==
-template <typename T>
-inline bool operator!= (const T& x, const T& y)
-{
- return (!(x == y));
-}
-
-/// Template of making > from <
-template <typename T>
-inline bool operator> (const T& x, const T& y)
-{
- return (y < x);
-}
-
-/// Template of making <= from < and ==
-template <typename T>
-inline bool operator<= (const T& x, const T& y)
-{
- return (!(y < x));
-}
-
-/// Template of making >= from < and ==
-template <typename T>
-inline bool operator>= (const T& x, const T& y)
-{
- return (!(x < y));
-}
-
-/// Packs \p s multiple times into \p b. Useful for loop unrolling.
-template <typename TSmall, typename TBig>
-inline void pack_type (TSmall s, TBig& b)
-{
- const size_t n = sizeof(TBig) / sizeof(TSmall);
- b = s;
- // Calls to min are here to avoid warnings for shifts bigger than the type. min will be gone when optimized.
- if (n < 2) return;
- b = (b << min (BitsInType(TSmall), BitsInType(TBig))) | b;
- if (n < 4) return;
- b = (b << min (BitsInType(TSmall) * 2, BitsInType(TBig))) | b;
- if (n < 8) return;
- b = (b << min (BitsInType(TSmall) * 4, BitsInType(TBig))) | b;
-}
-
-#if __GNUC__ >= 3
-inline bool TestAndSet (int* pm) __attribute__((always_inline));
-#endif
-/// Sets the contents of \p pm to 1 and returns true if the previous value was 0.
-inline bool TestAndSet (int* pm)
-{
-#if CPU_HAS_CMPXCHG8
- bool rv;
- int oldVal (1);
- asm volatile ( // cmpxchg compares to %eax and swaps if equal
- "cmpxchgl %3, %1\n\t"
- "sete %0"
- : "=a" (rv), "=m" (*pm), "=r" (oldVal)
- : "2" (oldVal), "a" (0)
- : "memory");
- return (rv);
-#elif __i386__ || __x86_64__
- int oldVal (1);
- asm volatile ("xchgl %0, %1" : "=r"(oldVal), "=m"(*pm) : "0"(oldVal), "m"(*pm) : "memory");
- return (!oldVal);
-#elif __sparc32__ // This has not been tested
- int rv;
- asm volatile ("ldstub %1, %0" : "=r"(rv), "=m"(*pm) : "m"(pm));
- return (!rv);
-#else
- const int oldVal (*pm);
- *pm = 1;
- return (!oldVal);
-#endif
-}
-
-/// \brief This template is to be used for dereferencing a type-punned pointer without a warning.
-///
-/// When casting a local variable to an unrelated type through a pointer (for
-/// example, casting a float to a uint32_t without conversion), the resulting
-/// memory location can be accessed through either pointer, which violates the
-/// strict aliasing rule. While -fno-strict-aliasing option can be given to
-/// the compiler, eliminating this warning, inefficient code may result in
-/// some instances, because aliasing inhibits some optimizations. By using
-/// this template, and by ensuring the memory is accessed in one way only,
-/// efficient code can be produced without the warning. For gcc 4.1.0+.
-///
-template <typename DEST, typename SRC>
-inline DEST noalias (DEST, SRC* s)
-{
- union UPun { SRC s; DEST d; };
- return (((UPun*)(s))->d);
-}
-
-namespace simd {
- /// Call after you are done using SIMD algorithms for 64 bit tuples.
-#if CPU_HAS_MMX
- inline void reset_mmx (void) __attribute__((always_inline));
- #define ALL_MMX_REGS_CHANGELIST "mm0","mm1","mm2","mm3","mm4","mm5","mm6","mm7","st","st(1)","st(2)","st(3)","st(4)","st(5)","st(6)","st(7)"
- #if CPU_HAS_3DNOW
- inline void reset_mmx (void) { asm ("femms":::ALL_MMX_REGS_CHANGELIST); }
- #else
- inline void reset_mmx (void) { asm ("emms":::ALL_MMX_REGS_CHANGELIST); }
- #endif
-#else
- inline void reset_mmx (void) {}
-#endif
-} // namespace simd
-
-/// \brief Type that is not size_t
-///
-/// Because size_t may be declared as unsigned long or unsigned int on
-/// different machines, this macro is convenient when defining overloads
-/// of size_t to use other types.
-///
-#if defined(SIZE_T_IS_LONG) && !defined(__ARM_EABI__)
- #define NOT_SIZE_T_I_OR_L unsigned int
-#else
- #define NOT_SIZE_T_I_OR_L unsigned long
-#endif
-
-/// \brief Required when you want to overload size_t and a pointer.
-///
-/// The compiler will happily cast a number to a pointer and declare
-/// that the overload is ambiguous unless you define overloads for all
-/// possible integral types that a number may represent. This behaviour,
-/// although braindead, is in the ANSI standard, and thus not a bug. If
-/// you want to change the standard, the best solution is to disallow any
-/// implicit casts to pointer from an integral type. Ironically, such an
-/// implicit cast is already detected by gcc.
-///
-#if defined(USTL_ANDROID_X86)
-#define OVERLOAD_POINTER_AND_SIZE_T_V2(name, arg1type)
-#else
-#define OVERLOAD_POINTER_AND_SIZE_T_V2(name, arg1type) \
- inline void name (arg1type a1, short a2) { name (a1, size_t(a2)); } \
- inline void name (arg1type a1, unsigned short a2) { name (a1, size_t(a2)); } \
- inline void name (arg1type a1, int a2) { name (a1, size_t(a2)); } \
- inline void name (arg1type a1, long a2) { name (a1, size_t(a2)); } \
- inline void name (arg1type a1, NOT_SIZE_T_I_OR_L a2) { name (a1, size_t(a2)); }
-#endif
-} // namespace ustl
-
-
-#endif
-
diff --git a/media/libdrm/mobile2/src/util/ustl-1.0/uvector.h b/media/libdrm/mobile2/src/util/ustl-1.0/uvector.h
deleted file mode 100644
index ccbc45b..0000000
--- a/media/libdrm/mobile2/src/util/ustl-1.0/uvector.h
+++ /dev/null
@@ -1,277 +0,0 @@
-// This file is part of the ustl library, an STL implementation.
-//
-// Copyright (C) 2005 by Mike Sharov <msharov@users.sourceforge.net>
-// This file is free software, distributed under the MIT License.
-//
-// uvector.h
-//
-
-#ifndef UVECTOR_H_00BB13AF082BEB7829C031B265518169
-#define UVECTOR_H_00BB13AF082BEB7829C031B265518169
-
-#include "uassert.h"
-#include "memblock.h"
-#include "umemory.h"
-
-namespace ustl {
-
-/// \class vector uvector.h ustl.h
-/// \ingroup Sequences
-///
-/// \brief STL vector equivalent.
-///
-/// Provides a typed array-like interface to a managed memory block, including
-/// element access, iteration, modification, resizing, and serialization. In
-/// this design elements frequently undergo bitwise move, so don't put it in
-/// here if it doesn't support it. This mostly means having no self-pointers.
-///
-template <typename T>
-class vector {
-public:
- typedef T value_type;
- typedef value_type* pointer;
- typedef const value_type* const_pointer;
- typedef value_type& reference;
- typedef const value_type& const_reference;
- typedef pointer iterator;
- typedef const_pointer const_iterator;
- typedef memblock::size_type size_type;
- typedef memblock::written_size_type written_size_type;
- typedef memblock::difference_type difference_type;
- typedef ::ustl::reverse_iterator<iterator> reverse_iterator;
- typedef ::ustl::reverse_iterator<const_iterator> const_reverse_iterator;
-public:
- inline vector (void);
- inline explicit vector (size_type n);
- vector (size_type n, const T& v);
- vector (const vector<T>& v);
- vector (const_iterator i1, const_iterator i2);
- ~vector (void) throw();
- inline const vector<T>& operator= (const vector<T>& v);
- inline bool operator== (const vector<T>& v) { return (m_Data == v.m_Data); }
- inline operator cmemlink (void) const { return (cmemlink (m_Data)); }
- inline operator cmemlink (void) { return (cmemlink (m_Data)); }
- inline operator memlink (void) { return (memlink (m_Data)); }
- inline void reserve (size_type n, bool bExact = true);
- inline void resize (size_type n, bool bExact = true);
- inline size_type capacity (void) const { return (m_Data.capacity() / sizeof(T)); }
- inline size_type size (void) const { return (m_Data.size() / sizeof(T)); }
- inline size_type max_size (void) const { return (m_Data.max_size() / sizeof(T)); }
- inline bool empty (void) const { return (m_Data.empty()); }
- inline iterator begin (void) { return (iterator (m_Data.begin())); }
- inline const_iterator begin (void) const { return (const_iterator (m_Data.begin())); }
- inline iterator end (void) { return (iterator (m_Data.end())); }
- inline const_iterator end (void) const { return (const_iterator (m_Data.end())); }
- inline reverse_iterator rbegin (void) { return (reverse_iterator (end())); }
- inline const_reverse_iterator rbegin (void) const { return (const_reverse_iterator (end())); }
- inline reverse_iterator rend (void) { return (reverse_iterator (begin())); }
- inline const_reverse_iterator rend (void) const { return (const_reverse_iterator (begin())); }
- inline iterator iat (size_type i) { assert (i <= size()); return (begin() + i); }
- inline const_iterator iat (size_type i) const { assert (i <= size()); return (begin() + i); }
- inline reference at (size_type i) { assert (i < size()); return (begin()[i]); }
- inline const_reference at (size_type i) const { assert (i < size()); return (begin()[i]); }
- inline reference operator[] (size_type i) { return (at (i)); }
- inline const_reference operator[] (size_type i) const { return (at (i)); }
- inline reference front (void) { return (at(0)); }
- inline const_reference front (void) const { return (at(0)); }
- inline reference back (void) { assert (!empty()); return (end()[-1]); }
- inline const_reference back (void) const { assert (!empty()); return (end()[-1]); }
- inline void push_back (const T& v = T());
- inline void pop_back (void) { m_Data.memlink::resize (m_Data.size() - sizeof(T)); }
- inline void clear (void) { m_Data.clear(); }
- void deallocate (void) throw();
- inline void assign (const_iterator i1, const_iterator i2);
- inline void assign (size_type n, const T& v);
- inline void swap (vector<T>& v) { m_Data.swap (v.m_Data); }
- inline iterator insert (iterator ip, const T& v = T());
- inline iterator insert (iterator ip, size_type n, const T& v);
- inline iterator insert (iterator ip, const_iterator i1, const_iterator i2);
- inline iterator erase (iterator ep, size_type n = 1);
- inline iterator erase (iterator ep1, iterator ep2);
- inline void manage (pointer p, size_type n) { m_Data.manage (p, n * sizeof(T)); }
- inline bool is_linked (void) const { return (m_Data.is_linked()); }
- inline void unlink (void) { m_Data.unlink(); }
- inline void copy_link (void) { m_Data.copy_link(); }
- inline void link (const_pointer p, size_type n) { m_Data.link (p, n * sizeof(T)); }
- inline void link (pointer p, size_type n) { m_Data.link (p, n * sizeof(T)); }
- inline void link (const vector<T>& v) { m_Data.link (v); }
- inline void link (vector<T>& v) { m_Data.link (v); }
- inline void link (const_pointer first, const_pointer last) { m_Data.link (first, last); }
- inline void link (pointer first, pointer last) { m_Data.link (first, last); }
- OVERLOAD_POINTER_AND_SIZE_T_V2(link, pointer)
- OVERLOAD_POINTER_AND_SIZE_T_V2(link, const_pointer)
-private:
- inline iterator insert_space (iterator ip, size_type n);
-private:
- memblock m_Data; ///< Raw element data, consecutively stored.
-};
-
-/// Allocates space for at least \p n elements.
-template <typename T>
-void vector<T>::reserve (size_type n, bool bExact)
-{
- const size_type oldCapacity = capacity();
- m_Data.reserve (n * sizeof(T), bExact);
- if (capacity() > oldCapacity)
- construct (begin() + oldCapacity, begin() + capacity());
-}
-
-/// Resizes the vector to contain \p n elements.
-template <typename T>
-void vector<T>::resize (size_type n, bool bExact)
-{
- if (m_Data.capacity() < n * sizeof(T))
- reserve (n, bExact);
- m_Data.memlink::resize (n * sizeof(T));
-}
-
-/// Calls element destructors and frees storage.
-template <typename T>
-void vector<T>::deallocate (void) throw()
-{
- if (!is_linked())
- destroy (begin(), begin() + capacity());
- m_Data.deallocate();
-}
-
-/// Initializes empty vector.
-template <typename T>
-inline vector<T>::vector (void)
-: m_Data ()
-{
-}
-
-/// Initializes a vector of size \p n.
-template <typename T>
-inline vector<T>::vector (size_type n)
-: m_Data ()
-{
- resize (n);
-}
-
-/// Copies \p n elements from \p v.
-template <typename T>
-vector<T>::vector (size_type n, const T& v)
-: m_Data ()
-{
- resize (n);
- ::ustl::fill (begin(), end(), v);
-}
-
-/// Copies \p v.
-template <typename T>
-vector<T>::vector (const vector<T>& v)
-: m_Data ()
-{
- resize (v.size());
- ::ustl::copy (v.begin(), v.end(), begin());
-}
-
-/// Copies range [\p i1, \p i2]
-template <typename T>
-vector<T>::vector (const_iterator i1, const_iterator i2)
-: m_Data ()
-{
- resize (distance (i1, i2));
- ::ustl::copy (i1, i2, begin());
-}
-
-/// Destructor
-template <typename T>
-inline vector<T>::~vector (void) throw()
-{
- if (!numeric_limits<value_type>::is_integral)
- deallocate();
-}
-
-/// Copies the range [\p i1, \p i2]
-template <typename T>
-inline void vector<T>::assign (const_iterator i1, const_iterator i2)
-{
- assert (i1 <= i2);
- resize (distance (i1, i2));
- ::ustl::copy (i1, i2, begin());
-}
-
-/// Copies \p n elements with value \p v.
-template <typename T>
-inline void vector<T>::assign (size_type n, const T& v)
-{
- resize (n);
- ::ustl::fill (begin(), end(), v);
-}
-
-/// Copies contents of \p v.
-template <typename T>
-inline const vector<T>& vector<T>::operator= (const vector<T>& v)
-{
- assign (v.begin(), v.end());
- return (*this);
-}
-
-/// Inserts \p n uninitialized elements at \p ip.
-template <typename T>
-typename vector<T>::iterator vector<T>::insert_space (iterator ip, size_type n)
-{
- const uoff_t ipmi = distance (m_Data.begin(), memblock::iterator(ip));
- reserve (size() + n, false);
- return (iterator (m_Data.insert (m_Data.iat(ipmi), n * sizeof(T))));
-}
-
-/// Inserts \p n elements with value \p v at offsets \p ip.
-template <typename T>
-typename vector<T>::iterator vector<T>::insert (iterator ip, size_type n, const T& v)
-{
- ip = insert_space (ip, n);
- ::ustl::fill (ip, ip + n, v);
- return (ip);
-}
-
-/// Inserts value \p v at offset \p ip.
-template <typename T>
-typename vector<T>::iterator vector<T>::insert (iterator ip, const T& v)
-{
- *(ip = insert_space (ip, 1)) = v;
- return (ip);
-}
-
-/// Inserts range [\p i1, \p i2] at offset \p ip.
-template <typename T>
-typename vector<T>::iterator vector<T>::insert (iterator ip, const_iterator i1, const_iterator i2)
-{
- assert (i1 <= i2);
- ip = insert_space (ip, distance (i1, i2));
- ::ustl::copy (i1, i2, ip);
- return (ip);
-}
-
-/// Removes \p count elements at offset \p ep.
-template <typename T>
-inline typename vector<T>::iterator vector<T>::erase (iterator ep, size_type n)
-{
- return (iterator (m_Data.erase (memblock::iterator(ep), n * sizeof(T))));
-}
-
-/// Removes elements from \p ep1 to \p ep2.
-template <typename T>
-inline typename vector<T>::iterator vector<T>::erase (iterator ep1, iterator ep2)
-{
- assert (ep1 <= ep2);
- return (erase (ep1, distance(ep1, ep2)));
-}
-
-/// Inserts value \p v at the end of the vector.
-template <typename T>
-void vector<T>::push_back (const T& v)
-{
- resize (size() + 1, false);
- back() = v;
-}
-
-/// Use with vector classes to allocate and link to stack space. \p n is in elements.
-#define typed_alloca_link(m,T,n) (m).link ((T*) alloca ((n) * sizeof(T)), (n))
-
-} // namespace ustl
-
-#endif
-