1 : <?php
2 : /**
3 : * Licensed to the Apache Software Foundation (ASF) under one or more
4 : * contributor license agreements. See the NOTICE file distributed with
5 : * this work for additional information regarding copyright ownership.
6 : * The ASF licenses this file to You under the Apache License, Version 2.0
7 : * (the "License"); you may not use this file except in compliance with
8 : * the License. You may obtain a copy of the License at
9 : *
10 : * http://www.apache.org/licenses/LICENSE-2.0
11 : *
12 : * Unless required by applicable law or agreed to in writing, software
13 : * distributed under the License is distributed on an "AS IS" BASIS,
14 : * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 : * See the License for the specific language governing permissions and
16 : * limitations under the License.
17 : *
18 : * @package log4php
19 : */
20 :
21 : /**
22 : * @package log4php
23 : * @subpackage helpers
24 : */
25 : class LoggerBasicPatternConverter extends LoggerPatternConverter {
26 :
27 : /**
28 : * @var integer
29 : */
30 : private $type;
31 :
32 : /**
33 : * Constructor
34 : *
35 : * @param string $formattingInfo
36 : * @param integer $type
37 : */
38 : public function __construct($formattingInfo, $type) {
39 14 : parent::__construct($formattingInfo);
40 14 : $this->type = $type;
41 14 : }
42 :
43 : /**
44 : * @param LoggerLoggingEvent $event
45 : * @return string
46 : */
47 : public function convert($event) {
48 14 : switch($this->type) {
49 14 : case LoggerPatternParser::RELATIVE_TIME_CONVERTER:
50 0 : $timeStamp = $event->getTimeStamp();
51 0 : $startTime = LoggerLoggingEvent::getStartTime();
52 0 : return (string)(int)($timeStamp * 1000 - $startTime * 1000);
53 :
54 14 : case LoggerPatternParser::THREAD_CONVERTER:
55 3 : return $event->getThreadName();
56 :
57 14 : case LoggerPatternParser::LEVEL_CONVERTER:
58 13 : $level = $event->getLevel();
59 13 : return $level->toString();
60 :
61 13 : case LoggerPatternParser::NDC_CONVERTER:
62 0 : return $event->getNDC();
63 :
64 13 : case LoggerPatternParser::MESSAGE_CONVERTER:
65 13 : return $event->getRenderedMessage();
66 :
67 0 : default:
68 0 : return '';
69 0 : }
70 : }
71 : }
|