View Javadoc

1   /*-
2    * #%L
3    * prolobjectlink-jpi-jpl7
4    * %%
5    * Copyright (C) 2012 - 2019 Prolobjectlink Project
6    * %%
7    * Redistribution and use in source and binary forms, with or without
8    * modification, are permitted provided that the following conditions are met:
9    * 
10   * 1. Redistributions of source code must retain the above copyright notice,
11   *    this list of conditions and the following disclaimer.
12   * 2. Redistributions in binary form must reproduce the above copyright notice,
13   *    this list of conditions and the following disclaimer in the documentation
14   *    and/or other materials provided with the distribution.
15   * 
16   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19   * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
20   * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21   * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22   * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23   * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24   * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26   * POSSIBILITY OF SUCH DAMAGE.
27   * #L%
28   */
29  package io.github.prolobjectlink.prolog.jpl7;
30  
31  import java.io.IOException;
32  import java.text.SimpleDateFormat;
33  import java.util.Date;
34  import java.util.logging.FileHandler;
35  import java.util.logging.Formatter;
36  import java.util.logging.Handler;
37  import java.util.logging.Level;
38  import java.util.logging.Logger;
39  
40  import io.github.prolobjectlink.prolog.AbstractLogger;
41  import io.github.prolobjectlink.prolog.PrologLogger;
42  
43  /**
44   * 
45   * @author Jose Zalacain
46   * @since 1.0
47   */
48  final class JplLogger extends AbstractLogger implements PrologLogger {
49  
50  	private static final String MESSAGE = "Logger File Handler can't be created";
51  	private static final Logger LOGGER = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME);
52  
53  	JplLogger() {
54  		this(Level.INFO);
55  	}
56  
57  	private JplLogger(Level level) {
58  		LOGGER.setLevel(level);
59  		Logger rootlogger = LOGGER.getParent();
60  		SimpleDateFormat f = new SimpleDateFormat("yyyy.MM.dd");
61  		String date = f.format(new Date());
62  		Formatter formatter = new JplFormatter();
63  		for (Handler h : rootlogger.getHandlers()) {
64  			h.setFormatter(formatter);
65  			h.setLevel(level);
66  		}
67  		FileHandler file = null;
68  		try {
69  			file = new FileHandler("%t/prolobjectlink-" + date + ".log", true);
70  		} catch (SecurityException e) {
71  			rootlogger.log(Level.SEVERE, MESSAGE, e);
72  		} catch (IOException e) {
73  			rootlogger.log(Level.SEVERE, MESSAGE, e);
74  		}
75  		assert file != null;
76  		file.setFormatter(formatter);
77  		LOGGER.addHandler(file);
78  	}
79  
80  	public void log(Object sender, Level level, Object message, Throwable throwable) {
81  		LOGGER.log(level, sender + "\n" + message, throwable);
82  	}
83  
84  }