private void addMatR(invType mat, int amount, int depth, bool start = false) { if (mat == null) { return; } if (mat.isBaseMat()) { baseMats.Add(mat, amount); } else { METEData data = null; this.meteDatas.TryGetValue(mat, out data); bool hadMEData = true; if (data == null) { data = this.defaultMETE; hadMEData = false; } string matStr = ""; for (int i = 0; i < depth; i++) { matStr += "-"; } if (!hadMEData || start) { this.QMMatsGrid.Rows.Add(matStr + mat, amount, "", "", "", "", "", ""); } else { string[] mesStrs = data.ToStrArray(); this.QMMatsGrid.Rows.Add(matStr + mat, amount, mesStrs[0], mesStrs[1], mesStrs[2], mesStrs[3], mesStrs[4], mesStrs[5]); } var matlist = mat.getMats(amount, data.TotalMEAsMultiplier); foreach (KeyValuePair <invType, int> submat in matlist) { addMatR(submat.Key, submat.Value, depth + 1); } } }