protected void DoTree(TreeNode parent, RCCube right, ref double a, ref double g) { if (right.Axis.ColCount > 1) { // throw new NotImplementedException ("Cannot handle time cols on cubes yet."); // But we will still handle them as if the time col didn't exist. } if (right.Axis.Symbol != null) { Dictionary <RCSymbolScalar, TreeNode> map = new Dictionary <RCSymbolScalar, TreeNode> (); for (int i = 0; i < right.Cols; ++i) { string colName = right.ColumnAt(i); TreeNode colNode = new TreeNode(parent, colName, i); colNode.v = colName; colNode.n = 0; ColumnBase col = right.GetColumn(i); bool numeric = typeof(long).IsAssignableFrom(col.GetElementType()); for (int j = 0; j < col.Count; ++j) { RCSymbolScalar symbol = right.Axis.SymbolAt(col.Index[j]); TreeNode rowNode = new TreeNode(colNode, symbol.Key.ToString(), col.Index[j]); object box = col.BoxCell(j); if (numeric) { rowNode.n = (long)box; rowNode.m = (long)box; rowNode.g = Math.Abs((long)box); } else { rowNode.n = 1; rowNode.m = 1; rowNode.g = 1; } rowNode.v = box.ToString(); colNode.n += rowNode.n; colNode.g += Math.Abs(rowNode.n); map[rowNode.s] = rowNode; } a += colNode.n; g += Math.Abs(colNode.g); } } else { for (int i = 0; i < right.Cols; ++i) { string colName = right.ColumnAt(i); TreeNode colNode = new TreeNode(parent, colName, i); colNode.v = colName; colNode.n = 0; ColumnBase col = right.GetColumn(i); bool numeric = typeof(long).IsAssignableFrom(col.GetElementType()); for (int j = 0; j < right.Count; ++j) { TreeNode rowNode = new TreeNode(colNode, null, col.Index[j]); object box = col.BoxCell(j); if (numeric) { rowNode.n = (long)box; rowNode.m = (long)box; rowNode.g = Math.Abs((long)box); } else { rowNode.n = 1; rowNode.m = 1; rowNode.g = 1; } rowNode.v = box.ToString(); colNode.n += rowNode.n; colNode.g += Math.Abs(rowNode.n); } a += colNode.n; g += Math.Abs(colNode.g); } } }