You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					99 lines
				
				2.6 KiB
			
		
		
			
		
	
	
					99 lines
				
				2.6 KiB
			| 
								 
											14 years ago
										 
									 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Copyright © 2012 Martin Minarik
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 
											11 years ago
										 
									 | 
							
								 * Permission is hereby granted, free of charge, to any person obtaining
							 | 
						||
| 
								 | 
							
								 * a copy of this software and associated documentation files (the
							 | 
						||
| 
								 | 
							
								 * "Software"), to deal in the Software without restriction, including
							 | 
						||
| 
								 | 
							
								 * without limitation the rights to use, copy, modify, merge, publish,
							 | 
						||
| 
								 | 
							
								 * distribute, sublicense, and/or sell copies of the Software, and to
							 | 
						||
| 
								 | 
							
								 * permit persons to whom the Software is furnished to do so, subject to
							 | 
						||
| 
								 | 
							
								 * the following conditions:
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								 *
							 | 
						||
| 
								 
											11 years ago
										 
									 | 
							
								 * The above copyright notice and this permission notice (including the
							 | 
						||
| 
								 | 
							
								 * next paragraph) shall be included in all copies or substantial
							 | 
						||
| 
								 | 
							
								 * portions of the Software.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
							 | 
						||
| 
								 | 
							
								 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
							 | 
						||
| 
								 | 
							
								 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
							 | 
						||
| 
								 | 
							
								 * NONINFRINGEMENT.  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
							 | 
						||
| 
								 | 
							
								 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
							 | 
						||
| 
								 | 
							
								 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
							 | 
						||
| 
								 | 
							
								 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
							 | 
						||
| 
								 | 
							
								 * SOFTWARE.
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								#include "config.h"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								#include <stdio.h>
							 | 
						||
| 
								 | 
							
								#include <stdarg.h>
							 | 
						||
| 
								 | 
							
								#include <stdlib.h>
							 | 
						||
| 
								 | 
							
								#include <string.h>
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								#include <sys/time.h>
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								#include <time.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <wayland-util.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								#include "compositor.h"
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											10 years ago
										 
									 | 
							
								static log_func_t log_handler = 0;
							 | 
						||
| 
								 | 
							
								static log_func_t log_continue_handler = 0;
							 | 
						||
| 
								 
											11 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											10 years ago
										 
									 | 
							
								/** Install the log handler
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * The given functions will be called to output text as passed to the
							 | 
						||
| 
								 | 
							
								 * \a weston_log and \a weston_log_continue functions.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * \param log The log function. This function will be called when
							 | 
						||
| 
								 | 
							
								 *            \a weston_log is called, and should begin a new line,
							 | 
						||
| 
								 | 
							
								 *            with user defined line headers, if any.
							 | 
						||
| 
								 | 
							
								 * \param cont The continue log function. This function will be called
							 | 
						||
| 
								 | 
							
								 *             when \a weston_log_continue is called, and should append
							 | 
						||
| 
								 | 
							
								 *             its output to the current line, without any header or
							 | 
						||
| 
								 | 
							
								 *             other content in between.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								WL_EXPORT void
							 | 
						||
| 
								 | 
							
								weston_log_set_handler(log_func_t log, log_func_t cont)
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								{
							 | 
						||
| 
								 
											10 years ago
										 
									 | 
							
									log_handler = log;
							 | 
						||
| 
								 | 
							
									log_continue_handler = cont;
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								WL_EXPORT int
							 | 
						||
| 
								 | 
							
								weston_vlog(const char *fmt, va_list ap)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 
											10 years ago
										 
									 | 
							
									return log_handler(fmt, ap);
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								WL_EXPORT int
							 | 
						||
| 
								 | 
							
								weston_log(const char *fmt, ...)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
									int l;
							 | 
						||
| 
								 | 
							
									va_list argp;
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
									va_start(argp, fmt);
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
									l = weston_vlog(fmt, argp);
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
									va_end(argp);
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
									return l;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								WL_EXPORT int
							 | 
						||
| 
								 | 
							
								weston_vlog_continue(const char *fmt, va_list argp)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 
											10 years ago
										 
									 | 
							
									return log_continue_handler(fmt, argp);
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
								WL_EXPORT int
							 | 
						||
| 
								 | 
							
								weston_log_continue(const char *fmt, ...)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
									int l;
							 | 
						||
| 
								 | 
							
									va_list argp;
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
									va_start(argp, fmt);
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
									l = weston_vlog_continue(fmt, argp);
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
									va_end(argp);
							 | 
						||
| 
								 
											13 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											14 years ago
										 
									 | 
							
									return l;
							 | 
						||
| 
								 | 
							
								}
							 |