14a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/*---------------------------------------------------------------------------*
24a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  pLastError.c  *
34a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
44a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Copyright 2007, 2008 Nuance Communciations, Inc.                               *
54a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
64a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Licensed under the Apache License, Version 2.0 (the 'License');          *
74a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  you may not use this file except in compliance with the License.         *
84a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
94a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  You may obtain a copy of the License at                                  *
104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0                           *
114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Unless required by applicable law or agreed to in writing, software      *
134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  distributed under the License is distributed on an 'AS IS' BASIS,        *
144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  See the License for the specific language governing permissions and      *
164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  limitations under the License.                                           *
174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *---------------------------------------------------------------------------*/
194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "pLastError.h"
214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "plog.h"
224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectvoid printGetLastErrorInternal(const LCHAR* text, char* file, int line)
244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#ifdef _WIN32
264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  LCHAR* msg;
274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if (FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER |
294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project                    FORMAT_MESSAGE_FROM_SYSTEM |
304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project                    FORMAT_MESSAGE_IGNORE_INSERTS,
314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project                    NULL,
324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project                    GetLastError(),
334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project                    MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), /* Default language */
344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project                    (LPTSTR) &msg,
354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project                    0,
364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project                    NULL))
374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  {
384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    ESR_BOOL isInit;
394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    ESR_ReturnCode rc;
404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    msg[LSTRLEN(msg)-2] = L('\0'); /* cut off newline character */
414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    rc = PLogIsInitialized(&isInit);
434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if (rc != ESR_SUCCESS)
444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      isInit = FALSE;
454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if (isInit)
464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      PLogError(L("%s: %s"), text, msg);
474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    else
484a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      pfprintf(PSTDERR, L("[%s:%d] %s: %s\n"), file, line, text, msg);
494a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    LocalFree(msg);
504a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
514a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#elif defined(__vxworks)
524a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  int err;
534a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
544a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  err = errnoGet(); /* get the error status value of the calling task */
554a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#ifndef NDEBUG
564a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  /*  printErrno(err); */ /* need special flag to build Simulator */
574a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#endif
584a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  pfprintf(PSTDERR, "[%s:%d] %s, errno = %x\n", file, line, text, err);
594a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
604a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#elif (OS == OS_UNIX)
614a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
624a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#else
634a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#error("Have not implemented yet!!!")
644a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#endif
654a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
66