/* Title: Pure/Tools/check_source.scala
Author: Makarius
Some sanity checks for Isabelle sources.
*/
package isabelle
object Check_Source
{
def check_file(path: Path)
{
val file_name = path.implode
val file_pos = path.position
def line_pos(i: Int) = Position.Line_File(i + 1, file_name)
val content = File.read(path)
for { (line, i) <- split_lines(content).iterator.zipWithIndex }
{
try {
Symbol.decode_strict(line)
for { c <- Word.codepoint_iterator(line); if c > 128 && !Character.isAlphabetic(c) }
{
Output.warning("Suspicious Unicode character " + quote(new String(Array(c), 0, 1)) +
Position.here(line_pos(i)))
}
}
catch { case ERROR(msg) => Output.error_message(msg + Position.here(line_pos(i))) }
if (line.contains('\t'))
Output.warning("TAB character " + Position.here(line_pos(i)))
}
if (content.contains('\r'))
Output.warning("CR character " + Position.here(file_pos))
}
}