Skip to content

cws1989/java-prettify

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Java Prettify

Java Prettify is discontinued.

Menu

Overview

This library is a java port of Google Prettify, the current version ported is 1-Jun-2011. The copyright holder of the Google Prettify is Mike Samuel ([email protected]). It is licensed under the Apache license Version 2. This port is written by Chan Wai Shing ([email protected]) distributed under Apache license Version 2.

Alternatives

Java SyntaxHighlighter

Requirement

Java SE 6 or up

Language Supported

The comments in prettify.parser.Prettify are authoritative but the lexer should work on a number of languages including C and friends, Java, Python, Bash, SQL, HTML, XML, CSS, Javascript, and Makefiles. It works passably on Ruby, PHP, VB, and Awk and a decent subset of Perl and Ruby, but, because of commenting conventions, doesn't work on Smalltalk, or CAML-like languages.

LISPy languages are supported via an extension: prettify.lang.LangLisp.

And similarly for Clojure, CSS, Go, Haskell, Lua, OCAML, SML, F#, Nemerle, Protocol Buffers, Scala, SQL, TeX, LaTeX, VHDL, Visual Basic, WikiText, XQuery, and YAML.

If you'd like to add an extension for your favorite language, please look at prettify.lang.LangLisp and file an issue including your language extension, and a testcase.

Adapted from: https://github.com/google/code-prettify/blob/master/README.md

Themes

Default, Desert, Sons of Obsidian, Sunburst

Click here to visit the gallery.

Configurations

  • Allows you to change the first (starting) line number.
  • Allows you to turn gutter with line numbers on and off.
  • Allows you to highlight one or more lines to focus user's attention.

Click here for a demo.

Example

Note that this highlighter extends Swing component, so all operations are better be executed inside Swing dispatching thread.

import java.io.*;
import java.util.Arrays;
import java.util.logging.*;
import javax.swing.*;
import prettify.PrettifyParser;
import prettify.theme.ThemeDefault;
import syntaxhighlight.*;

public class Example {

  public static void main(String[] args) {
    SwingUtilities.invokeLater(new Runnable() {

      @Override
      public void run() {
        // the Prettify parser
        Parser parser = new PrettifyParser();

        // initialize the highlighter and use Default theme
        SyntaxHighlighter highlighter = new SyntaxHighlighter(parser, new ThemeDefault());
        // set the line number count from 10 instead of 1
        highlighter.setFirstLine(10);
        // set to highlight line 13, 27, 28, 38, 42, 43 and 53
        highlighter.setHighlightedLineList(Arrays.asList(13, 27, 28, 38, 42, 43, 53));
        try {
          highlighter.setContent(new File("test.html"));
        } catch (IOException ex) {
          Logger.getLogger(Example.class.getName()).log(Level.SEVERE, null, ex);
        }

        JFrame frame = new JFrame();
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.setContentPane(highlighter);
        frame.setLocationByPlatform(true);
        frame.pack();
        frame.setVisible(true);
      }
    });
  }
}

Sample Screenshot

ThemeDesert

Support & Discussion

Support & Discussion Group

Known Issues

  • Perl formatting is really crappy. Partly because Perl is hard to parse.

Adapted from: https://github.com/google/code-prettify/blob/master/CHANGES.md

Google Project

https://code.google.com/archive/p/java-prettify/

About

Java port of Google Prettify

Resources

Stars

Watchers

Forks

Packages

No packages published