Skip to content

Commit

Permalink
Add new Object package
Browse files Browse the repository at this point in the history
Currently performs no error checking, but this can be added later. The plan is to also add a schema for each class.
  • Loading branch information
ianhinder committed Sep 13, 2013
1 parent 0349644 commit 9347b58
Show file tree
Hide file tree
Showing 2 changed files with 138 additions and 0 deletions.
71 changes: 71 additions & 0 deletions Tests/Object.mt
@@ -0,0 +1,71 @@

(* Mathematica Test File *)


(****************************************************************)
(* NewObject *)
(****************************************************************)

Test[
NewObject[Obj, {}]
,
Obj[]
,
TestID->"NewObject-Empty"
]

Test[
NewObject[Obj, {"Key" -> 1}]
,
Obj["Key" -> 1]
,
TestID->"NewObject-OneKey"
]

Test[
NewObject[Obj, {"Key1" -> 1, "Key2" -> 2}]
,
Obj["Key1" -> 1, "Key2" -> 2]
,
TestID->"NewObject-TwoKeys"
]

Test[
SetObjectField[NewObject[Obj, {"Key1" -> 1, "Key2" -> 2}], "Key1", 3]
,
Obj["Key1" -> 3, "Key2" -> 2]
,
TestID->"SetObjectField-Existing"
]

Test[
SetObjectField[NewObject[Obj, {"Key1" -> 1, "Key2" -> 2}], "Key3", 3]
,
Obj["Key1" -> 1, "Key2" -> 2, "Key3" -> 3]
,
TestID->"SetObjectField-New"
]

Test[
GetObjectField[NewObject[Obj, {"Key1" -> 1, "Key2" -> 2}], "Key1"]
,
1
,
TestID->"GetObjectField-Exists"
]

Test[
AppendObjectField[NewObject[Obj, {"Key1" -> {}, "Key2" -> 2}], "Key1", 1]
,
Obj["Key1" -> {1}, "Key2" -> 2]
,
TestID->"AppendObjectField-Exists"
]

Test[
JoinObjectField[NewObject[Obj, {"Key1" -> {}, "Key2" -> 2}], "Key1", {1}]
,
Obj["Key1" -> {1}, "Key2" -> 2]
,
TestID->"JoinObjectField-Exists"
]
67 changes: 67 additions & 0 deletions Tools/CodeGen/Object.m
@@ -0,0 +1,67 @@

(* Copyright 2013 Ian Hinder
This file is part of Kranc.
Kranc 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 of the License, or
(at your option) any later version.
Kranc is distributed 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 Kranc; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*)

BeginPackage["Object`", {"Errors`", "Helpers`", "Kranc`"}];

NewObject;
SetObjectField;
GetObjectField;
AppendObjectField;
JoinObjectField;

Begin["`Private`"];

(* Low-level functions *)

DefFn[
NewObject[class_Symbol, initList_List] :=
Apply[class, initList]];

DefFn[
keys[obj_] :=
Sort[Map[First, obj]]];

DefFn[
hasValueQ[obj_, field_] :=
MemberQ[keys[obj], field]];

DefFn[
SetObjectField[obj_, field_String, value_] :=
If[Length[Cases[obj, HoldPattern[field -> _]]] > 0,
Replace[obj, (field -> _) :> field -> value, {1}],
Append[obj, field -> value]]];

DefFn[
GetObjectField[obj_, field_String] :=
Cases[obj, (field -> value_) :> value][[1]]];

(* High level functions *)

DefFn[
AppendObjectField[obj_, field_String, value_] :=
SetObjectField[obj, field, Append[GetObjectField[obj, field], value]]];

DefFn[
JoinObjectField[obj_, field_String, values_List] :=
SetObjectField[obj, field, Join[GetObjectField[obj, field], values]]];

End[];

EndPackage[];

0 comments on commit 9347b58

Please sign in to comment.