// This module implements the TQextScintillaLexerLua class.
//
// Copyright (c) 2006
// 	Riverbank Computing Limited <info@riverbankcomputing.co.uk>
// 
// This file is part of TQScintilla.
// 
// This copy of TQScintilla is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2, or (at your option) any
// later version.
// 
// TQScintilla is supplied in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
// details.
// 
// You should have received a copy of the GNU General Public License along with
// TQScintilla; see the file LICENSE.  If not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.

#ifdef HAVE_CONFIG_H
#  include "config.h"
#endif

#include <tqcolor.h>
#include <tqfont.h>
#include <tqsettings.h>

#include "tqextscintillalexerlua.h"


// The ctor.
TQextScintillaLexerLua::TQextScintillaLexerLua(TQObject *parent, const char *name)
	: TQextScintillaLexer(parent,name), fold_compact(true)
{
}


// The dtor.
TQextScintillaLexerLua::~TQextScintillaLexerLua()
{
}


// Returns the language name.
const char *TQextScintillaLexerLua::language() const
{
	return "Lua";
}


// Returns the lexer name.
const char *TQextScintillaLexerLua::lexer() const
{
	return "lua";
}


// Return the list of characters that can start a block.
const char *TQextScintillaLexerLua::blockStart(int *style) const
{
	if (style)
		*style = Operator;

	return "";
}


// Return the style used for braces.
int TQextScintillaLexerLua::braceStyle() const
{
	return Operator;
}


// Returns the foreground colour of the text for a style.
TQColor TQextScintillaLexerLua::color(int style) const
{
	switch (style)
	{
	case Default:
		return TQColor(0x00,0x00,0x00);

	case Comment:
	case LineComment:
		return TQColor(0x00,0x7f,0x00);

	case Number:
		return TQColor(0x00,0x7f,0x7f);

	case Keyword:
	case BasicFunctions:
	case StringTableMathsFunctions:
	case CoroutinesIOSystemFacilities:
		return TQColor(0x00,0x00,0x7f);

	case String:
	case Character:
	case LiteralString:
		return TQColor(0x7f,0x00,0x7f);

	case Preprocessor:
		return TQColor(0x7f,0x7f,0x00);

	case Operator:
	case Identifier:
		break;
	}

	return TQextScintillaLexer::color(style);
}


// Returns the end-of-line fill for a style.
bool TQextScintillaLexerLua::eolFill(int style) const
{
	return (style == Comment || style == UnclosedString);
}


// Returns the font of the text for a style.
TQFont TQextScintillaLexerLua::font(int style) const
{
	TQFont f;

	switch (style)
	{
	case Comment:
	case LineComment:
	case LiteralString:
#if defined(Q_OS_WIN)
		f = TQFont("Comic Sans MS",9);
#else
		f = TQFont("Bitstream Vera Serif",9);
#endif
		break;

	default:
		f = TQextScintillaLexer::font(style);
	}

	return f;
}


// Returns the set of keywords.
const char *TQextScintillaLexerLua::keywords(int set) const
{
	if (set == 1)
		// Keywords.
		return
			"and break do else elseif end false for function if "
			"in local nil not or repeat return then true until "
			"while";

	if (set == 2)
		// Basic functions.
		return
			"_ALERT _ERRORMESSAGE _INPUT _PROMPT _OUTPUT _STDERR "
			"_STDIN _STDOUT call dostring foreach foreachi getn "
			"globals newtype rawget rawset require sort tinsert "
			"tremove "

			"G getfenv getmetatable ipairs loadlib next pairs "
			"pcall rawegal rawget rawset require setfenv "
			"setmetatable xpcall string table math coroutine io "
			"os debug";

	if (set == 3)
		// String, table and maths functions.
		return
			"abs acos asin atan atan2 ceil cos deg exp floor "
			"format frexp gsub ldexp log log10 max min mod rad "
			"random randomseed sin sqrt strbyte strchar strfind "
			"strlen strlower strrep strsub strupper tan "

			"string.byte string.char string.dump string.find "
			"string.len string.lower string.rep string.sub "
			"string.upper string.format string.gfind string.gsub "
			"table.concat table.foreach table.foreachi table.getn "
			"table.sort table.insert table.remove table.setn "
			"math.abs math.acos math.asin math.atan math.atan2 "
			"math.ceil math.cos math.deg math.exp math.floor "
			"math.frexp math.ldexp math.log math.log10 math.max "
			"math.min math.mod math.pi math.rad math.random "
			"math.randomseed math.sin math.sqrt math.tan";

	if (set == 4)
		// Coroutine, I/O and system facilities.
		return
			"openfile closefile readfrom writeto appendto remove "
			"rename flush seek tmpfile tmpname read write clock "
			"date difftime execute exit getenv setlocale time "

			"coroutine.create coroutine.resume coroutine.status "
			"coroutine.wrap coroutine.yield io.close io.flush "
			"io.input io.lines io.open io.output io.read "
			"io.tmpfile io.type io.write io.stdin io.stdout "
			"io.stderr os.clock os.date os.difftime os.execute "
			"os.exit os.getenv os.remove os.rename os.setlocale "
			"os.time os.tmpname";

	return 0;
}


// Returns the user name of a style.
TQString TQextScintillaLexerLua::description(int style) const
{
	switch (style)
	{
	case Default:
		return tr("Default");

	case Comment:
		return tr("Comment");

	case LineComment:
		return tr("Line comment");

	case Number:
		return tr("Number");

	case Keyword:
		return tr("Keyword");

	case String:
		return tr("String");

	case Character:
		return tr("Character");

	case LiteralString:
		return tr("Literal string");

	case Preprocessor:
		return tr("Preprocessor");

	case Operator:
		return tr("Operator");

	case Identifier:
		return tr("Identifier");

	case UnclosedString:
		return tr("Unclosed string");

	case BasicFunctions:
		return tr("Basic functions");

	case StringTableMathsFunctions:
		return tr("String, table and maths functions");

	case CoroutinesIOSystemFacilities:
		return tr("Coroutines, i/o and system facilities");
	}

	return TQString();
}


// Returns the background colour of the text for a style.
TQColor TQextScintillaLexerLua::paper(int style) const
{
	switch (style)
	{
	case Comment:
		return TQColor(0xd0,0xf0,0xf0);

	case LiteralString:
		return TQColor(0xe0,0xff,0xff);

	case UnclosedString:
		return TQColor(0xe0,0xc0,0xe0);

	case BasicFunctions:
		return TQColor(0xd0,0xff,0xd0);

	case StringTableMathsFunctions:
		return TQColor(0xd0,0xd0,0xff);

	case CoroutinesIOSystemFacilities:
		return TQColor(0xff,0xd0,0xd0);
	}

	return TQextScintillaLexer::paper(style);
}


// Refresh all properties.
void TQextScintillaLexerLua::refreshProperties()
{
	setCompactProp();
}


// Read properties from the settings.
bool TQextScintillaLexerLua::readProperties(TQSettings &qs,const TQString &prefix)
{
	bool rc = true;
	bool ok, flag;

	// Read the fold compact flag.
	flag = qs.readBoolEntry(prefix + "foldcompact",true,&ok);

	if (ok)
		fold_compact = flag;
	else
		rc = false;

	return rc;
}


// Write properties to the settings.
bool TQextScintillaLexerLua::writeProperties(TQSettings &qs,const TQString &prefix) const
{
	bool rc = true;

	// Write the fold compact flag.
	if (!qs.writeEntry(prefix + "foldcompact",fold_compact))
		rc = false;

	return rc;
}


// Return true if folds are compact.
bool TQextScintillaLexerLua::foldCompact() const
{
	return fold_compact;
}


// Set if folds are compact.
void TQextScintillaLexerLua::setFoldCompact(bool fold)
{
	fold_compact = fold;

	setCompactProp();
}


// Set the "fold.compact" property.
void TQextScintillaLexerLua::setCompactProp()
{
	emit propertyChanged("fold.compact",(fold_compact ? "1" : "0"));
}

#include "tqextscintillalexerlua.moc"