File: androiddebug.cpp

package info (click to toggle)
jamulus 3.6.2%2Bdfsg1-3
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 16,444 kB
  • sloc: ansic: 53,088; cpp: 19,791; sh: 4,697; asm: 723; makefile: 346; perl: 264; python: 56; xml: 37
file content (81 lines) | stat: -rw-r--r-- 2,389 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/******************************************************************************\
 * Copyright (c) 2020
 *
 * Author(s):
 *  Simon Tomlinson
 *
 ******************************************************************************
 *
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU General Public License as published by the Free Software
 * Foundation; either version 2 of the License, or (at your option) any later
 * version.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License along with
 * this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
 *
\******************************************************************************/

const char*const applicationName = "Jamulus";

#ifdef ANDROIDDEBUG // Set in my myapp.pro file for android builds
#include <android/log.h>
#include <QString>
#include <QEvent>
#include <QDebug>
#include <stdio.h>
#include <math.h>
#include <string>

void myMessageHandler ( QtMsgType type, const QMessageLogContext& context, const QString& msg )
{
  QString report = msg;

  if ( context.file && !QString ( context.file ).isEmpty() )
  {
    report += " in file ";
    report += QString ( context.file );
    report += " line ";
    report += QString::number ( context.line );
  }

  if ( context.function && !QString ( context.function ).isEmpty() )
  {
    report +=+" function ";
    report += QString(context.function);
  }

  const char*const local = report.toLocal8Bit().constData();

  switch ( type )
  {
  case QtDebugMsg:
    __android_log_write ( ANDROID_LOG_DEBUG, applicationName, local) ;
    break;

  case QtInfoMsg:
    __android_log_write ( ANDROID_LOG_INFO, applicationName, local );
    break;

  case QtWarningMsg:
    __android_log_write ( ANDROID_LOG_WARN, applicationName, local );
    break;

  case QtCriticalMsg:
    __android_log_write ( ANDROID_LOG_ERROR, applicationName, local );
    break;

  case QtFatalMsg:
  default:
    __android_log_write ( ANDROID_LOG_FATAL, applicationName, local );
    abort();
    break;
  }
}
#endif