added some error-checking & syntax-highlighting

This commit is contained in:
zueuk 2006-12-09 20:51:31 +00:00
parent 8121918b55
commit 0bc843839f

View File

@ -191,6 +191,7 @@ type
procedure TransformClearProc(AMachine: TatVirtualMachine); procedure TransformClearProc(AMachine: TatVirtualMachine);
procedure TransformRotateProc(AMachine: TatVirtualMachine); procedure TransformRotateProc(AMachine: TatVirtualMachine);
procedure TransformScaleProc(AMachine: TatVirtualMachine);
procedure TransformRotateOriginProc(AMachine: TatVirtualMachine); procedure TransformRotateOriginProc(AMachine: TatVirtualMachine);
{ Render interface } { Render interface }
@ -350,6 +351,9 @@ uses Main, Editor, Adjust, Global, Mutate, Registry, Preview,
{$R *.DFM} {$R *.DFM}
const
ErrorOutOfRange = 'Transform out of range!';
type type
{ Library for math functions } { Library for math functions }
TMathLibrary = class(TatScripterLibrary) TMathLibrary = class(TatScripterLibrary)
@ -1388,7 +1392,7 @@ end;
procedure TOperationLibrary.RotateProc(AMachine: TatVirtualMachine); procedure TOperationLibrary.RotateProc(AMachine: TatVirtualMachine);
begin begin
try try
if (ActiveTransform < 0) or (ActiveTransform >= ScriptEditor.cp.NumXForms) then raise EFormatInvalid.Create('Transform out of range.'); if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then raise EFormatInvalid.Create(ErrorOutOfRange);
with AMachine do with AMachine do
ScriptEditor.cp.xform[ActiveTransform].Rotate(GetInputArgAsFloat(0)); ScriptEditor.cp.xform[ActiveTransform].Rotate(GetInputArgAsFloat(0));
except on E: EFormatInvalid do except on E: EFormatInvalid do
@ -1403,7 +1407,7 @@ end;
procedure TOperationLibrary.MulProc(AMachine: TatVirtualMachine); procedure TOperationLibrary.MulProc(AMachine: TatVirtualMachine);
begin begin
try try
if (ActiveTransform < 0) or (ActiveTransform >= ScriptEditor.cp.NumXForms) then raise EFormatInvalid.Create('Transform out of range.'); if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then raise EFormatInvalid.Create(ErrorOutOfRange);
with AMachine do with AMachine do
ScriptEditor.cp.xform[ActiveTransform].Multiply(GetInputArgAsFloat(0), GetInputArgAsFloat(1), GetInputArgAsFloat(2), GetInputArgAsFloat(3)); ScriptEditor.cp.xform[ActiveTransform].Multiply(GetInputArgAsFloat(0), GetInputArgAsFloat(1), GetInputArgAsFloat(2), GetInputArgAsFloat(3));
except on E: EFormatInvalid do except on E: EFormatInvalid do
@ -1726,7 +1730,7 @@ end;
procedure TOperationLibrary.ScaleProc(AMachine: TatVirtualMachine); procedure TOperationLibrary.ScaleProc(AMachine: TatVirtualMachine);
begin begin
try try
if (ActiveTransform < 0) or (ActiveTransform >= ScriptEditor.cp.NumXForms) then raise EFormatInvalid.Create('Transform out of range.'); if (ActiveTransform < 0) or (ActiveTransform >= ScriptEditor.cp.NumXForms) then raise EFormatInvalid.Create(ErrorOutOfRange);
with AMachine do with AMachine do
ScriptEditor.cp.xform[ActiveTransform].Scale(GetInputArgAsFloat(0)); ScriptEditor.cp.xform[ActiveTransform].Scale(GetInputArgAsFloat(0));
except on E: EFormatInvalid do except on E: EFormatInvalid do
@ -1879,8 +1883,12 @@ var
begin begin
NumTransforms := 0; NumTransforms := 0;
ActiveTransform := -1; ActiveTransform := -1;
{
for i := 0 to NXFORMS - 1 do for i := 0 to NXFORMS - 1 do
ScriptEditor.cp.xform[i].density := 0; ScriptEditor.cp.xform[i].density := 0;
}
ScriptEditor.cp.Clear;
ScriptEditor.cp.xform[0].symmetry := 1;
end; end;
procedure TOperationLibrary.MorphProc(AMachine: TatVirtualMachine); procedure TOperationLibrary.MorphProc(AMachine: TatVirtualMachine);
@ -1939,7 +1947,7 @@ begin
i := GetInputArgAsInteger(0); i := GetInputArgAsInteger(0);
if (i >= 0) and (i < NXFORMS) then if (i >= 0) and (i < NXFORMS) then
ActiveTransform := i ActiveTransform := i
else raise EFormatInvalid.Create('Transform out of range.'); else raise EFormatInvalid.Create(ErrorOutOfRange);
except on E: EFormatInvalid do except on E: EFormatInvalid do
begin begin
Application.ProcessMessages; Application.ProcessMessages;
@ -2067,7 +2075,7 @@ procedure TOperationLibrary.TranslateProc(AMachine: TatVirtualMachine);
begin begin
try try
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then // was: NXFORMS-1 if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then // was: NXFORMS-1
raise EFormatInvalid.Create('Transform out of range.'); raise EFormatInvalid.Create(ErrorOutOfRange);
with AMachine do with AMachine do
ScriptEditor.cp.xform[ActiveTransform].Translate(GetInputArgAsFloat(0), GetInputArgAsFloat(1)); ScriptEditor.cp.xform[ActiveTransform].Translate(GetInputArgAsFloat(0), GetInputArgAsFloat(1));
except on E: EFormatInvalid do except on E: EFormatInvalid do
@ -2766,12 +2774,24 @@ var
i: integer; i: integer;
v: double; v: double;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
with AMachine do with AMachine do
begin begin
i := 0; i := 0;
while (i < NRVAR) and (varnames(i) <> CurrentPropertyName) do Inc(i); while (i < NRVAR) and (varnames(i) <> CurrentPropertyName) do Inc(i);
// if (i >= NRVAR) then error if (i < NRVAR) then
ReturnOutPutArg(cp.xform[ActiveTransform].vars[i]); ReturnOutPutArg(cp.xform[ActiveTransform].vars[i])
else begin // shouldn't happen
LastError := 'Oops!';
ScriptEditor.Console.Lines.Add(LastError);
Scripter.Halt;
end;
end; end;
end; end;
@ -2780,13 +2800,24 @@ var
i: integer; i: integer;
v: double; v: double;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
with AMachine do with AMachine do
begin begin
i := 0; i := 0;
while (i < NRVAR) and (varnames(i) <> CurrentPropertyName) do Inc(i); while (i < NRVAR) and (varnames(i) <> CurrentPropertyName) do Inc(i);
if (i < NRVAR) then if (i < NRVAR) then
cp.xform[ActiveTransform].vars[i] := GetInputArgAsFloat(0); cp.xform[ActiveTransform].vars[i] := GetInputArgAsFloat(0)
//else error else begin // shouldn't happen
LastError := 'Oops!';
ScriptEditor.Console.Lines.Add(LastError);
Scripter.Halt;
end;
end; end;
end; end;
@ -2794,6 +2825,13 @@ procedure TScriptEditor.GetTransformVariableProc(AMachine: TatVirtualMachine);
var var
v: double; v: double;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
with AMachine do with AMachine do
begin begin
cp.xform[ActiveTransform].GetVariable(CurrentPropertyName, v); cp.xform[ActiveTransform].GetVariable(CurrentPropertyName, v);
@ -2805,6 +2843,13 @@ procedure TScriptEditor.SetTransformVariableProc(AMachine: TatVirtualMachine);
var var
v: double; v: double;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
with AMachine do with AMachine do
begin begin
v := GetInputArgAsFloat(0); v := GetInputArgAsFloat(0);
@ -2819,6 +2864,13 @@ var
v: double; v: double;
i, j: integer; i, j: integer;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
with AMachine do begin with AMachine do begin
i := GetArrayIndex(0); i := GetArrayIndex(0);
j := GetArrayIndex(1); j := GetArrayIndex(1);
@ -2835,6 +2887,13 @@ var
v: double; v: double;
i, j: integer; i, j: integer;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
with AMachine do with AMachine do
begin begin
v := GetInputArgAsFloat(0); v := GetInputArgAsFloat(0);
@ -2852,6 +2911,13 @@ var
v: double; v: double;
i, j: integer; i, j: integer;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
with AMachine do begin with AMachine do begin
i := GetArrayIndex(0); i := GetArrayIndex(0);
j := GetArrayIndex(1); j := GetArrayIndex(1);
@ -2868,6 +2934,13 @@ var
v: double; v: double;
i, j: integer; i, j: integer;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
with AMachine do with AMachine do
begin begin
v := GetInputArgAsFloat(0); v := GetInputArgAsFloat(0);
@ -2893,6 +2966,13 @@ procedure TScriptEditor.TransformRotateOriginProc(AMachine: TatVirtualMachine);
var var
tx, ty, rad: double; tx, ty, rad: double;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
rad := AMachine.GetInputArgAsFloat(0) * pi / 180; rad := AMachine.GetInputArgAsFloat(0) * pi / 180;
with EditForm.WorldPivot do with EditForm.WorldPivot do
with cp.xform[ActiveTransform] do begin with cp.xform[ActiveTransform] do begin
@ -2903,7 +2983,7 @@ begin
end; end;
end; end;
// -- pivot-aware rotating -- // -- pivot-aware rotating & scaling --
procedure TScriptEditor.TransformRotateProc(AMachine: TatVirtualMachine); procedure TScriptEditor.TransformRotateProc(AMachine: TatVirtualMachine);
var var
@ -2912,6 +2992,13 @@ var
tx: TXForm; tx: TXForm;
begin begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
tx := TXForm.Create; tx := TXForm.Create;
tx.Assign(scripteditor.cp.xform[NumTransforms]); // just in case (?) tx.Assign(scripteditor.cp.xform[NumTransforms]); // just in case (?)
@ -2925,6 +3012,33 @@ begin
tx.Free; tx.Free;
end; end;
procedure TScriptEditor.TransformScaleProc(AMachine: TatVirtualMachine);
var
Triangles: TTriangles;
px, py: double;
tx: TXForm;
begin
if (ActiveTransform < 0) or (ActiveTransform > NXFORMS) then begin
ScriptEditor.Console.Lines.Add(ErrorOutOfRange);
LastError := ErrorOutOfRange;
Scripter.Halt;
exit;
end;
tx := TXForm.Create;
tx.Assign(scripteditor.cp.xform[NumTransforms]); // just in case (?)
EditForm.ScriptGetPivot(px, py);
cp.TrianglesFromCp(Triangles); // it's ugly but it works...
Triangles[ActiveTransform] :=
ScaleTrianglePoint(Triangles[ActiveTransform], px, py, AMachine.GetInputArgAsFloat(0));
cp.GetFromTriangles(Triangles, NumTransforms);
cp.xform[NumTransforms].Assign(tx);
tx.Free;
end;
{ *************************** Render interface ****************************** } { *************************** Render interface ****************************** }
@ -2997,6 +3111,7 @@ begin
DefineProp('MaxMemory', tkInteger, GetRenderMaxMemoryProc, SetRenderMaxMemoryProc); DefineProp('MaxMemory', tkInteger, GetRenderMaxMemoryProc, SetRenderMaxMemoryProc);
end; end;
Scripter.AddObject('Renderer', Renderer); Scripter.AddObject('Renderer', Renderer);
{ Flame interface } { Flame interface }
with Scripter.defineClass(TFlame) do with Scripter.defineClass(TFlame) do
begin begin
@ -3024,6 +3139,7 @@ begin
DefineProp('FinalXformEnabled', tkInteger, GetFlameFinalxformEnabledProc, SetFlameFinalxformEnabledProc); DefineProp('FinalXformEnabled', tkInteger, GetFlameFinalxformEnabledProc, SetFlameFinalxformEnabledProc);
end; end;
Scripter.AddObject('Flame', Flame); Scripter.AddObject('Flame', Flame);
{ Transform interface } { Transform interface }
with Scripter.defineClass(TTransform) do with Scripter.defineClass(TTransform) do
begin begin
@ -3032,13 +3148,20 @@ begin
DefineProp('Color', tkFloat, GetTransformColorProc, SetTransformColorProc); DefineProp('Color', tkFloat, GetTransformColorProc, SetTransformColorProc);
DefineProp('Weight', tkFloat, GetTransformWeightProc, SetTransformWeightProc); DefineProp('Weight', tkFloat, GetTransformWeightProc, SetTransformWeightProc);
DefineProp('Symmetry', tkFloat, GetTransformSymProc, SetTransformSymProc); DefineProp('Symmetry', tkFloat, GetTransformSymProc, SetTransformSymProc);
for i:= 0 to NRVAR - 1 do for i:= 0 to NRVAR - 1 do begin
DefineProp(Varnames(i), tkFloat, GetTransformVariationProc, SetTransformVariationProc); DefineProp(Varnames(i), tkFloat, GetTransformVariationProc, SetTransformVariationProc);
for i:= 0 to GetNrVariableNames - 1 do Editor.SyntaxStyles.AutoCompletion.Add(Varnames(i));
end;
for i:= 0 to GetNrVariableNames - 1 do begin
DefineProp(GetVariableNameAt(i), tkFloat, GetTransformVariableProc, SetTransformVariableProc); DefineProp(GetVariableNameAt(i), tkFloat, GetTransformVariableProc, SetTransformVariableProc);
Editor.SyntaxStyles.AutoCompletion.Add(GetVariableNameAt(i));
end;
Editor.SyntaxStyles.AutoCompletion.Sort;
while Editor.SyntaxStyles.AutoCompletion.Strings[0] = '' do Editor.SyntaxStyles.AutoCompletion.Delete(0);
DefineMethod('Clear', 0, tkNone, nil, TransformClearProc); DefineMethod('Clear', 0, tkNone, nil, TransformClearProc);
DefineMethod('Rotate', 1, tkNone, nil, TransformRotateProc); DefineMethod('Rotate', 1, tkNone, nil, TransformRotateProc);
DefineMethod('Scale', 1, tkNone, nil, TransformScaleProc);
DefineMethod('RotateOrigin', 1, tkNone, nil, TransformRotateOriginProc); DefineMethod('RotateOrigin', 1, tkNone, nil, TransformRotateOriginProc);
DefineProp('a', tkFloat, GetTransformAProc, SetTransformAProc); DefineProp('a', tkFloat, GetTransformAProc, SetTransformAProc);
@ -3050,6 +3173,7 @@ begin
DefineProp('Variation', tkFloat, GetTransformVarProc, SetTransformVarProc, nil, false, 1); DefineProp('Variation', tkFloat, GetTransformVarProc, SetTransformVarProc, nil, false, 1);
end; end;
Scripter.AddObject('Transform', Transform); Scripter.AddObject('Transform', Transform);
{ Options interface } { Options interface }
with Scripter.defineClass(TOptions) do with Scripter.defineClass(TOptions) do
begin begin
@ -3105,6 +3229,7 @@ begin
Scripter.AddObject('Options', Options); Scripter.AddObject('Options', Options);
Scripter.AddLibrary(TOperationLibrary); Scripter.AddLibrary(TOperationLibrary);
Scripter.AddLibrary(TatClassesLibrary); Scripter.AddLibrary(TatClassesLibrary);
{ Variables and constants } { Variables and constants }
Scripter.AddConstant('PI', pi); Scripter.AddConstant('PI', pi);
Scripter.AddConstant('NVARS', NRVAR); Scripter.AddConstant('NVARS', NRVAR);
@ -3177,7 +3302,7 @@ begin
*) *)
{ Variables } { Variables }
Scripter.AddVariable('SelectedTransform', EditForm.SelectedTriangle); Scripter.AddVariable('SelectedTransform', EditForm.SelectedTriangle);
Scripter.AddVariable('Compatibility', Compatibility); Scripter.AddVariable('Compatibility', Compatibility); // obsolete
Scripter.AddVariable('ActiveTransform', ActiveTransform); Scripter.AddVariable('ActiveTransform', ActiveTransform);
Scripter.AddVariable('UpdateFlame', UpdateIt); Scripter.AddVariable('UpdateFlame', UpdateIt);
Scripter.AddVariable('ResetLocation', ResetLocation); Scripter.AddVariable('ResetLocation', ResetLocation);
@ -3187,6 +3312,7 @@ begin
Scripter.AddVariable('ShowProgress', ShowProgress); Scripter.AddVariable('ShowProgress', ShowProgress);
Scripter.AddVariable('CurrentFile', OpenFile); Scripter.AddVariable('CurrentFile', OpenFile);
Scripter.AddVariable('LimitVibrancy', LimitVibrancy); Scripter.AddVariable('LimitVibrancy', LimitVibrancy);
Scripter.AddLibrary(TMathLibrary); Scripter.AddLibrary(TMathLibrary);
Scripter.AddLibrary(TatMathLibrary); Scripter.AddLibrary(TatMathLibrary);
// Scripter.AddLibrary(TatWindowsLibrary); // Scripter.AddLibrary(TatWindowsLibrary);