무슨 깡으로 블로그에 SyntaxHighlighter 테스트를 하는지 모르겠으나, ANSI 컬러로 SQL colorize하는 소스코드를 붙여본다.
/*
* Copyright (c) 1999-2012, Jang-Ho Hwang, rath@xrath.com.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer. Redistributions in
* binary form must reproduce the above copyright notice, this list of
* conditions and the following disclaimer in the documentation and/or
* other materials provided with the distribution. Neither the name of the
* Jang-Ho Hwang nor the names of its contributors may be used to endorse or
* promote products derived from this software without specific prior written
* permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*/
package rath.adrenaline.tool.colorize;
import rath.adrenaline.pcre.MatchResult;
import rath.adrenaline.pcre.Pattern;
import rath.adrenaline.pcre.Replacer;
import rath.adrenaline.pcre.Substitution;
import rath.adrenaline.util.ANSI;
/**
* Created by IntelliJ IDEA.
* User: rath
* Date: 21/01/2011
* Time: 22:13
*/
public class SqlColorize {
private static Pattern keywordsPattern = Pattern.compile(
"\\b(SELECT|FROM|INSERT|INTO|VALUES|UPDATE|SET|DELETE|VALUES|WHERE|" +
"LIKE|AND|ORDER BY|OR|GROUP BY|HAVING|UNION|LIMIT|USING|JOIN|OUTER|IS|NOT|ASC|DESC)\\b",
Pattern.CASE_INSENSITIVE);
private static Pattern constantPattern = Pattern.compile(
"\\b([0-9]+|NULL|true|false)\\b", Pattern.CASE_INSENSITIVE
);
private static Pattern stringPattern = Pattern.compile("('[^']+')");
private static Pattern functionPattern = Pattern.compile(
"\\b(COUNT|CONCAT|LENGTH|LOWER|UPPER|SUBSTRING|TRIM|" +
"ADDDATE|ADDTIME|CURDATE|NOW|DATE)\\b",
Pattern.CASE_INSENSITIVE);
private static Replacer keywordsReplacer = keywordsPattern.replacer(new Substitution() {
public void append(MatchResult matchResult, StringBuilder buf) {
String keyword = matchResult.group(1);
buf.append(ANSI.CYAN_BOLD);
buf.append(keyword);
buf.append(ANSI.RESET);
}
});
private static Replacer constantReplacer = constantPattern.replacer(new Substitution() {
public void append(MatchResult matchResult, StringBuilder buf) {
String constant = matchResult.group(1);
buf.append(ANSI.GREEN);
buf.append(constant);
buf.append(ANSI.RESET);
}
});
private static Replacer stringReplacer = stringPattern.replacer(new Substitution() {
public void append(MatchResult matchResult, StringBuilder buf) {
String constant = matchResult.group(1);
buf.append(ANSI.MAGENTA);
buf.append(constant);
buf.append(ANSI.RESET);
}
});
private static Replacer functionReplacer = functionPattern.replacer(new Substitution() {
public void append(MatchResult matchResult, StringBuilder buf) {
String constant = matchResult.group(1);
buf.append(ANSI.YELLOW);
buf.append(constant);
buf.append(ANSI.RESET);
}
});
public static String colorize(String sql) {
sql = constantReplacer.replace(sql);
sql = keywordsReplacer.replace(sql);
sql = stringReplacer.replace(sql);
sql = functionReplacer.replace(sql);
return sql;
}
}
워드프레스 LightWord 테마때문에 80 컬럼 안지킨거 딱 걸려서 테마설정 Layout settings => wider로 바꿨다. Java에서는 120컬럼 정도가 어떠할지.
Comments
1 thoughts shared
Continue Reading
Discover more thoughts and insights
영화와 프로그래밍은 기억을 지운다
나는 영화 보기와 프로그래밍을 비슷하게 취급하는 경향이 있다. 둘 다 한 번 시작하면 적어도 2~3시간은 다른 짓을 못하기 때문에 머리에서 굴리고 있던 것들이 부서져버린다. 그래서 시작하기를 꺼린다. 일단 시작하게
Read more
버스비
제이워크의 '여우비' 패러디인 '버스비' 입니다. Comments 엄허 2007-12-28T01:59:33.000Z 너무 웃겨요~ ㅋ 왠지 공감
Read more
자자 2007년 출근 2번째
어제 밤에 생긴 몇가지 미션과 회의 의사소통을 처리하다보니 오후 3시가 되버리고 다시 즐거운 코딩 라이프를 하다보니 6시가 되었다. 모든 것이 갖추어진 좋은 환경에서 기계적으로 코딩하는 것보단 계획에 없었던
Read more