~ci-train-bot/mir/mir-ubuntu-zesty-2683

« back to all changes in this revision

Viewing changes to 3rd_party/android-deps/android/log.h

  • Committer: Bileto Bot
  • Date: 2017-04-13 15:26:17 UTC
  • mfrom: (1160.2883.164 0.27)
  • Revision ID: ci-train-bot@canonical.com-20170413152617-bs7slz07xbzxu2d3
* New upstream release 0.27.0 (https://launchpad.net/mir/+milestone/0.27.0)
  - ABI summary:
    . mirclient ABI unchanged at 9
    . mirserver ABI bumped to 44
    . mircommon ABI unchanged at 7
    . mirplatform ABI bumped to 61
    . mirprotobuf ABI unchanged at 3
    . mirplatformgraphics ABI bumped to 13
    . mirclientplatform ABI unchanged at 5
    . mirinputplatform ABI bumped to 7
    . mircore ABI unchanged at 1
  - Enhancements:
    . Mostly groundwork required to support major enhancements coming in
      future Mir versions.
    . Removed android-input and eliminated the entire "3rd_party/" subtree.
      Now the Mir source tree contains original code only.
    . Added mir_prompt_session_new_fds_for_prompt_providers_sync API.
    . mirout: Added load and save options for keeping display configs
      on disk.
    . mirout: Added "--" support for applying configuration changes under
      Unity8.
    . Fixed failure of DRM hardware cursor {hide(); show(image);}
    . Added server option: "--cursor software" (MIR_SERVER_CURSOR=software)
    . Added letterboxing/black bars support to the GL renderer in preparation
      for generic output cloning.
    . Added client API for getting the logical size of an output.
    . Migrated MirCookie to use SHA-256.
    . Ensure RealKMSOutputConfiguration stays in sync with actual hardware
      state.
    . Added support for drag-and-drop.
    . Lots of other client API enhancements.
    . Minor clean-ups, optimizations and dead code removal.
  - Bugs fixed:
    . [enhancement] Make able to get version information from client /
      server APIs (LP: #1195540)
    . Touch screen coordinates don't rotate with the screen (LP: #1349660)
    . Subpixel order not included in Mir display information (LP: #1393578)
    . [enhancement] Missing client API for relative surface movement (e.g.
      dragging client-decorated windows) (LP: #1420334) . Mir does not reset
      key states when paused or resumed (modifiers get stuck after VT
      switching) (LP: #1536279)
    . Inconsistent behaviour of Num Lock (LP: #1588237)
    . [ FAILED ] NestedInput.nested_event_filter_receives_keyboard_from_host
      (LP: #1613523)
    . Rotating an output left or right without restarting the
      compositor distorts the image (LP: #1643488)
    . support display scaling slider in unity8 (LP: #1645372)
    . [ FAILED ] NestedInputWithMouse.mouse_pointer_coordinates_in_nested_
      server_are_accumulated (LP: #1646375)
    . [ FAILED ] NestedInputWithMouse.mouse_pointer_position_is_in_sync_with_
      host_server (LP: #1646558)
    . abi_check doesn't check mircore (LP: #1649354)
    . Under Unity8, mir_demo_client_target is distorted and input in the
      wrong place on start-up (LP: #1655804)
    . [testsfail] PromptSessionClientAPI.client_pid_is_associated_with_
      session hangs and times out (LP: #1655929)
    . EDID does not change when hotplugging a monitor (LP: #1660017)
    . [regression] Mir 0.26.0 - spinner loading animation, minimize, maximize
      too fast (LP: #1661072)
    . [regression] Unity8 stutters constantly (like half frame rate) using
      Mir 0.26.0 (LP: #1661128)
    . [regression] mir_demo_server refuses to quit on Ctrl+Alt+Backspace or
      Ctrl+C in its terminal (deadlock in DefaultInputDeviceHub::add_device)
      (LP: #1661151)
    . [regression] mirout crashes when connecting to unity8 or any nested
      server: [libprotobuf FATAL
      /usr/include/google/protobuf/repeated_field.h:1408] CHECK failed:
      (index) < (current_size_): (LP: #1661163)
    . [ FAILED ] DefaultInputManagerTest.forwards_pause_continue_state_
      changes_to_platform (LP: #1661187)
    . [regression] Segfault on detect_fd_leaks during acceptance tests (in
      DisplayConfiguration/{DisplayFormatSetting,DisplaySubpixelSetting})
      (LP: #1661498)
    . [regression] Nested server segfaults or rapidly logs exceptions when a
      fullscreen client starts [in mir_presentation_chain_set_dropping_mode
      ... std::exception::what: Operation not permitted] (LP: #1661508)
    . [regression] Windowed clients of nested servers are all black
      (LP: #1661521)
    . mir_window_request_persistent_id_sync seg faults when called twice
      (LP: #1661704)
    . mir_acceptance_tests now takes 10 seconds longer (in r4002 compared to
      r4001) (LP: #1662044)
    . Mir graphics platform ABI broke in series 0.26 but sonames never
      changed (LP: #1662455)
    . libmirclient-dev missing build depndency on libmircore-dev
      (LP: #1662942)
    . [regression] mirscreencast hangs during screencast creation
      (LP: #1662997)
    . [regression] Software clients of nested servers with size >=480x480
      are all black in Mir 0.25.0 and later (or stretched and distorted under
      Unity8) (LP: #1663062)
    . mir_window_spec_set_cursor_name() doesn't trigger
      mir::scene::SurfaceObserver::cursor_image_set_to (LP: #1663197)
    . android complaint during mirscreencast of nested server (LP: #1664562)
    . qtubuntu sends wrong text as part of QKeyEvent (LP: #1664610)
    . Mir server crashed with SIGSEGV in
      mir::compositor::TemporaryBuffer::size() called from
      mir::gl::tessellate_renderable_into_rectangle() (LP: #1664760)
    . mirout reports logical size of a rotated display incorrectly
      (LP: #1665271)
    . Nested servers (Unity8) periodically stutter (half frame rate) with
      Mir 0.26.1 (LP: #1666372)
    . If the only surface in a session cannot take focus the server crashes
      (LP: #1667645)
    . [regression] OSK input shaping no longer works correctly (LP: #1669444)
    . GTK window functions `Always on Top, Move and Resize' don't work in
      Mir/Unity8 (LP: #1669524)
    . [regression] mir_proving_server mode hotkeys (Ctrl+Alt+=/-) cause the
      server to segfault (LP: #1669752)
    . Test takes minutes to complete: MediatingDisplayChangerTest.confirmed_
      configuration_doesnt_revert_after_timeout (LP: #1671033)
    . [ FAILED ] PosixRWMutex.prefer_writer_nonrecursive_prevents_writer_
      starvation (Timeout waiting to acquire write lock) (LP: #1671037)
    . [regression] Mixing screen rotation with mode changes makes the image
      squished (LP: #1672269)
    . unity-system-compositor crashed with SIGSEGV in
      libinput_device_config_accel_is_available() from
      libinput_device_config_accel_set_speed() from
      mir::input::evdev::LibInputDevice::apply_settings() (LP: #1672955)
    . Presentation chains should support various Vulkan presentation modes
      (LP: #1673533)
    . Need an extension for GBM buffers to replace
      mir_buffer_get_buffer_package() (LP: #1673534)
    . cross-compile-chroot.sh (to zesty) fails to build [cannot find -ludev]
      due to libudev.so being in a different directory to where libudev.pc
      searches for it (LP: #1674201)
    . Please transition to Boost 1.62 (LP: #1675138)
    . [regression] Mir is assigning the first output ID = 0 (==
      mir_display_output_id_invalid) (LP: #1675331)
    . Mir sending key repeat events continually to nested shell after VT
      switch (causes Unity8 lockup for a while) (LP: #1675357)
    . mirout commands don't work when followed by -- (LP: #1676320)
    . mir_demo_standalone_render_overlays fails to link (LP: #1677239)
    . [regression] doxygen processing for capnproto/protobuf broken
      (LP: #1679248)
    . mir_window_spec_set_cursor_render_surface does not work (LP: #1679836)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 * Copyright (C) 2009 The Android Open Source Project
3
 
 *
4
 
 * Licensed under the Apache License, Version 2.0 (the "License");
5
 
 * you may not use this file except in compliance with the License.
6
 
 * You may obtain a copy of the License at
7
 
 *
8
 
 *      http://www.apache.org/licenses/LICENSE-2.0
9
 
 *
10
 
 * Unless required by applicable law or agreed to in writing, software
11
 
 * distributed under the License is distributed on an "AS IS" BASIS,
12
 
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
 
 * See the License for the specific language governing permissions and
14
 
 * limitations under the License.
15
 
 */
16
 
 
17
 
#ifndef _ANDROID_LOG_H
18
 
#define _ANDROID_LOG_H
19
 
 
20
 
/******************************************************************
21
 
 *
22
 
 * IMPORTANT NOTICE:
23
 
 *
24
 
 *   This file is part of Android's set of stable system headers
25
 
 *   exposed by the Android NDK (Native Development Kit) since
26
 
 *   platform release 1.5
27
 
 *
28
 
 *   Third-party source AND binary code relies on the definitions
29
 
 *   here to be FROZEN ON ALL UPCOMING PLATFORM RELEASES.
30
 
 *
31
 
 *   - DO NOT MODIFY ENUMS (EXCEPT IF YOU ADD NEW 32-BIT VALUES)
32
 
 *   - DO NOT MODIFY CONSTANTS OR FUNCTIONAL MACROS
33
 
 *   - DO NOT CHANGE THE SIGNATURE OF FUNCTIONS IN ANY WAY
34
 
 *   - DO NOT CHANGE THE LAYOUT OR SIZE OF STRUCTURES
35
 
 */
36
 
 
37
 
/*
38
 
 * Support routines to send messages to the Android in-kernel log buffer,
39
 
 * which can later be accessed through the 'logcat' utility.
40
 
 *
41
 
 * Each log message must have
42
 
 *   - a priority
43
 
 *   - a log tag
44
 
 *   - some text
45
 
 *
46
 
 * The tag normally corresponds to the component that emits the log message,
47
 
 * and should be reasonably small.
48
 
 *
49
 
 * Log message text may be truncated to less than an implementation-specific
50
 
 * limit (e.g. 1023 characters max).
51
 
 *
52
 
 * Note that a newline character ("\n") will be appended automatically to your
53
 
 * log message, if not already there. It is not possible to send several messages
54
 
 * and have them appear on a single line in logcat.
55
 
 *
56
 
 * PLEASE USE LOGS WITH MODERATION:
57
 
 *
58
 
 *  - Sending log messages eats CPU and slow down your application and the
59
 
 *    system.
60
 
 *
61
 
 *  - The circular log buffer is pretty small (<64KB), sending many messages
62
 
 *    might push off other important log messages from the rest of the system.
63
 
 *
64
 
 *  - In release builds, only send log messages to account for exceptional
65
 
 *    conditions.
66
 
 *
67
 
 * NOTE: These functions MUST be implemented by /system/lib/liblog.so
68
 
 */
69
 
 
70
 
#include <stdarg.h>
71
 
 
72
 
#ifdef __cplusplus
73
 
extern "C" {
74
 
#endif
75
 
 
76
 
/*
77
 
 * Android log priority values, in ascending priority order.
78
 
 */
79
 
typedef enum android_LogPriority {
80
 
    ANDROID_LOG_UNKNOWN = 0,
81
 
    ANDROID_LOG_DEFAULT,    /* only for SetMinPriority() */
82
 
    ANDROID_LOG_VERBOSE,
83
 
    ANDROID_LOG_DEBUG,
84
 
    ANDROID_LOG_INFO,
85
 
    ANDROID_LOG_WARN,
86
 
    ANDROID_LOG_ERROR,
87
 
    ANDROID_LOG_FATAL,
88
 
    ANDROID_LOG_SILENT     /* only for SetMinPriority(); must be last */
89
 
} android_LogPriority;
90
 
 
91
 
/*
92
 
 * Send a formatted string to the log, used like printf(fmt,...)
93
 
 */
94
 
int __android_log_print(int prio, const char *tag,  const char *fmt, ...)
95
 
#if defined(__GNUC__)
96
 
    __attribute__ ((format(printf, 3, 4)))
97
 
#endif
98
 
    ;
99
 
 
100
 
/*
101
 
 * A variant of __android_log_print() that takes a va_list to list
102
 
 * additional parameters.
103
 
 */
104
 
int __android_log_vprint(int prio, const char *tag,
105
 
                         const char *fmt, va_list ap);
106
 
 
107
 
/*
108
 
 * Log an assertion failure and SIGTRAP the process to have a chance
109
 
 * to inspect it, if a debugger is attached. This uses the FATAL priority.
110
 
 */
111
 
void __android_log_assert(const char *cond, const char *tag,
112
 
                          const char *fmt, ...)    
113
 
#if defined(__GNUC__)
114
 
    __attribute__ ((noreturn))
115
 
    __attribute__ ((format(printf, 3, 4)))
116
 
#endif
117
 
    ;
118
 
 
119
 
#ifdef __cplusplus
120
 
}
121
 
#endif
122
 
 
123
 
#endif /* _ANDROID_LOG_H */