Skip to content

Commit

Permalink
fix augmented ops
Browse files Browse the repository at this point in the history
  • Loading branch information
pzinn committed Nov 28, 2024
1 parent 45f7ca9 commit d101352
Showing 1 changed file with 23 additions and 25 deletions.
48 changes: 23 additions & 25 deletions M2/Macaulay2/d/evaluate.d
Original file line number Diff line number Diff line change
Expand Up @@ -1274,34 +1274,32 @@ augmentedAssignmentFun(x:augmentedAssignmentCode):Expr := (
else return r)
else return r);
-- if not, use default behavior
r:=nullE;
f:=s.binary; if f==dummyBinaryFun then
r=binarymethod(Code(left),x.rhs,SymbolClosure(globalFrame,s))
else
r=f(Code(left),x.rhs);
when r is e:Error do Expr(e) else (
when x.lhs
is y:globalMemoryReferenceCode do (
r := s.binary(Code(left), x.rhs);
when r is e:Error do Expr(e)
else globalAssignment(y.frameindex, x.info, r))
is y:localMemoryReferenceCode do (
r := s.binary(Code(left), x.rhs);
when r is e:Error do Expr(e)
else localAssignment(y.nestingDepth, y.frameindex, r))
is y:threadMemoryReferenceCode do (
r := s.binary(Code(left), x.rhs);
when r is e:Error do Expr(e)
else globalAssignment(y.frameindex, x.info, r))
is y:globalMemoryReferenceCode do globalAssignment(y.frameindex, x.info, r)
is y:localMemoryReferenceCode do localAssignment(y.nestingDepth, y.frameindex, r)
is y:threadMemoryReferenceCode do globalAssignment(y.frameindex, x.info, r)
is y:binaryCode do (
r := Code(binaryCode(s.binary, Code(left), x.rhs, dummyPosition));
if y.f == DotS.symbol.binary || y.f == SharpS.symbol.binary
then AssignElemFun(y.lhs, y.rhs, r)
else InstallValueFun(CodeSequence(
convertGlobalOperator(x.info), y.lhs, y.rhs, r)))
is y:adjacentCode do (
r := Code(binaryCode(s.binary, Code(left), x.rhs, dummyPosition));
InstallValueFun(CodeSequence(
convertGlobalOperator(AdjacentS.symbol), y.lhs, y.rhs, r)))
is y:unaryCode do (
r := Code(binaryCode(s.binary, Code(left), x.rhs, dummyPosition));
UnaryInstallValueFun(convertGlobalOperator(x.info), y.rhs, r))
if y.f == DotS.symbol.binary || y.f == SharpS.symbol.binary
then AssignElemFun(y.lhs, y.rhs, Code(evaluatedCode(r,dummyPosition)))
else InstallValueFun(CodeSequence(
convertGlobalOperator(x.info), y.lhs, y.rhs, Code(evaluatedCode(r,dummyPosition)))))
is y:ternaryCode do (
InstallValueFun(CodeSequence(
convertGlobalOperator(x.info), y.arg1, y.arg2, Code(evaluatedCode(r,dummyPosition))))) -- y.arg3 redundant -- combine with previous case?
is y:adjacentCode do (
InstallValueFun(CodeSequence(
convertGlobalOperator(AdjacentS.symbol), y.lhs, y.rhs, Code(evaluatedCode(r,dummyPosition)))))
is y:unaryCode do (
UnaryInstallValueFun(convertGlobalOperator(x.info), y.rhs, Code(evaluatedCode(r,dummyPosition))))
else buildErrorPacket(
"augmented assignment not implemented for this code")));
"augmented assignment not implemented for this code")
)));

-----------------------------------------------------------------------------
steppingFurther(c:Code):bool := steppingFlag && (
Expand Down

0 comments on commit d101352

Please sign in to comment.