Subversion Repository Public Repository

litesoft

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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
// This Source Code is in the Public Domain per: http://unlicense.org
package org.litesoft.GWT.client;

import org.litesoft.GWT.client.widgets.*;
import org.litesoft.logger.*;
import org.litesoft.logger.nonpublic.*;

public class TextAreaLogFactory extends SizeableTextArea {
    public TextAreaLogFactory() {
        super( false );
        setText( "" );
    }

    private static final String NEW_LINE = "\n";

    public void newLine() {
        append( NEW_LINE );
    }

    public void append( Object pObject ) {
        if ( isAttached() ) {
            setText( getText() + deNull( pObject ) );
        }
    }

    public void appendLine( Object pObject ) {
        append( deNull( pObject ) + NEW_LINE );
    }

    private String deNull( Object pObject ) {
        return String.valueOf( pObject );
    }

    public Logger createLogger( String pClassName, int pLoggerLevel ) {
        return new MyLogger( new LogHelper( this, pLoggerLevel ), pClassName );
    }

    private static class MyLogger extends Logger {
        public MyLogger( LogHelper pLogHelper, String pClassName ) {
            super( pLogHelper, pLogHelper, pClassName );
        }
    }

    private static class LogHelper implements ImplLoggerAdapterResolver,
                                              EnabledlogLevelAccessor {
        private TextAreaLogFactory mTextArea;
        private int mLoggerLevel;

        public LogHelper( TextAreaLogFactory pTextArea, int pLoggerLevel ) {
            mTextArea = pTextArea;
            mLoggerLevel = pLoggerLevel;
        }

        @Override
        public int getEnabledLevel() {
            return mLoggerLevel;
        }

        @Override
        public int getEnabledLevel( String pClassName ) {
            return getEnabledLevel();
        }

        @Override
        public ImplLoggerAdapter resolve( int pLevel, String pClassname ) {
            return new LoggerAdapter( mTextArea, LEVELS[pLevel], pClassname );
        }
    }

    private static class LoggerAdapter implements ImplLoggerAdapter {
        private TextAreaLogFactory mTextArea;
        private String mLevel, mClassname;

        public LoggerAdapter( TextAreaLogFactory pTextArea, String pLevel, String pClassname ) {
            mTextArea = pTextArea;
            mLevel = pLevel;
            mClassname = pClassname;
        }

        @Override
        public boolean isEnabled() {
            return true;
        }

        @Override
        public void log( String pText, Throwable pThrowable ) {
            addLine( toErr( pThrowable ), pText );
        }

        @Override
        public void log( String pText ) {
            addLine( "", pText );
        }

        private void addLine( String pErr, String pText ) {
            mTextArea.appendLine( "[" + mLevel + pErr + "]" + mClassname + " - " + pText );
        }

        private String toErr( Throwable pThrowable ) {
            return (pThrowable == null) ? "" : (",Err:" + pThrowable.getMessage());
        }
    }
}

Commits for litesoft/trunk/Java/GWT/OldClient/src/org/litesoft/GWT/client/TextAreaLogFactory.java

Diff revisions: vs.
Revision Author Commited Message
970 Diff Diff GeorgeS picture GeorgeS Mon 04 Aug, 2014 22:36:23 +0000

!

950 Diff Diff GeorgeS picture GeorgeS Thu 19 Jun, 2014 17:57:04 +0000

New Lines

948 Diff Diff GeorgeS picture GeorgeS Sat 07 Jun, 2014 23:42:39 +0000

Jusefuls Formatter Updated to New Code Format

947 Diff Diff GeorgeS picture GeorgeS Fri 06 Jun, 2014 23:36:56 +0000

Correct Spelling of package!

49 Diff Diff GeorgeS picture GeorgeS Mon 12 Apr, 2010 02:59:10 +0000

License Text

2 GeorgeS picture GeorgeS Sun 07 Feb, 2010 12:50:58 +0000