Hardware/Computer.cs
author paulwerelds
Tue, 21 Sep 2010 10:18:07 +0000
changeset 193 52ef1cf6b8e5
parent 171 81ab5e53122e
child 195 0ee888c485d5
permissions -rw-r--r--
Added thermal and voltage/frequency MSRs for K8 CPUs, fixed chars-per-line limit
moel@28
     1
/*
moel@28
     2
  
moel@28
     3
  Version: MPL 1.1/GPL 2.0/LGPL 2.1
moel@28
     4
moel@28
     5
  The contents of this file are subject to the Mozilla Public License Version
moel@28
     6
  1.1 (the "License"); you may not use this file except in compliance with
moel@28
     7
  the License. You may obtain a copy of the License at
moel@28
     8
 
moel@28
     9
  http://www.mozilla.org/MPL/
moel@28
    10
moel@28
    11
  Software distributed under the License is distributed on an "AS IS" basis,
moel@28
    12
  WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
moel@28
    13
  for the specific language governing rights and limitations under the License.
moel@28
    14
moel@28
    15
  The Original Code is the Open Hardware Monitor code.
moel@28
    16
moel@28
    17
  The Initial Developer of the Original Code is 
moel@28
    18
  Michael Möller <m.moeller@gmx.ch>.
moel@28
    19
  Portions created by the Initial Developer are Copyright (C) 2009-2010
moel@28
    20
  the Initial Developer. All Rights Reserved.
moel@28
    21
moel@28
    22
  Contributor(s):
moel@28
    23
moel@28
    24
  Alternatively, the contents of this file may be used under the terms of
moel@28
    25
  either the GNU General Public License Version 2 or later (the "GPL"), or
moel@28
    26
  the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
moel@28
    27
  in which case the provisions of the GPL or the LGPL are applicable instead
moel@28
    28
  of those above. If you wish to allow use of your version of this file only
moel@28
    29
  under the terms of either the GPL or the LGPL, and not to allow others to
moel@28
    30
  use your version of this file under the terms of the MPL, indicate your
moel@28
    31
  decision by deleting the provisions above and replace them with the notice
moel@28
    32
  and other provisions required by the GPL or the LGPL. If you do not delete
moel@28
    33
  the provisions above, a recipient may use your version of this file under
moel@28
    34
  the terms of any one of the MPL, the GPL or the LGPL.
moel@28
    35
 
moel@28
    36
*/
moel@28
    37
moel@28
    38
using System;
moel@28
    39
using System.Collections.Generic;
moel@182
    40
using System.Globalization;
moel@28
    41
using System.IO;
moel@167
    42
using System.Security.Permissions;
moel@167
    43
moel@28
    44
namespace OpenHardwareMonitor.Hardware {
moel@28
    45
moel@83
    46
  public class Computer : IComputer {
moel@28
    47
moel@28
    48
    private List<IGroup> groups = new List<IGroup>();
moel@28
    49
moel@28
    50
    private bool open = false;
moel@28
    51
    private bool hddEnabled = false;
moel@165
    52
    private ISettings settings;
moel@28
    53
moel@165
    54
    public Computer() {
moel@165
    55
      this.settings = new Settings();
moel@165
    56
    }
moel@165
    57
moel@165
    58
    public Computer(ISettings settings) {
moel@165
    59
      if (settings != null)
moel@165
    60
        this.settings = settings;
moel@165
    61
      else {
moel@165
    62
        this.settings = new Settings();
moel@165
    63
      }
moel@165
    64
    }
moel@28
    65
moel@28
    66
    private void Add(IGroup group) {
moel@28
    67
      if (groups.Contains(group))
moel@28
    68
        return;
moel@28
    69
moel@28
    70
      groups.Add(group);
moel@28
    71
moel@28
    72
      if (HardwareAdded != null)
moel@83
    73
        foreach (IHardware hardware in group.Hardware)
moel@28
    74
          HardwareAdded(hardware);
moel@28
    75
    }
moel@28
    76
moel@28
    77
    private void Remove(IGroup group) {
moel@28
    78
      if (!groups.Contains(group))
moel@28
    79
        return;
moel@28
    80
moel@28
    81
      groups.Remove(group);
moel@28
    82
moel@28
    83
      if (HardwareRemoved != null)
moel@83
    84
        foreach (IHardware hardware in group.Hardware)
moel@28
    85
          HardwareRemoved(hardware);
moel@28
    86
    }
moel@28
    87
moel@167
    88
    [SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode = true)]
moel@28
    89
    public void Open() {
moel@28
    90
      if (open)
moel@28
    91
        return;
moel@28
    92
moel@167
    93
      WinRing0.Open();
moel@167
    94
moel@165
    95
      Add(new Mainboard.MainboardGroup(settings));
moel@165
    96
      Add(new CPU.CPUGroup(settings));
moel@165
    97
      Add(new ATI.ATIGroup(settings));
moel@171
    98
      Add(new Nvidia.NvidiaGroup(settings));      
moel@165
    99
      Add(new TBalancer.TBalancerGroup(settings));
moel@171
   100
      Add(new Heatmaster.HeatmasterGroup(settings));
moel@28
   101
moel@83
   102
      if (hddEnabled)
moel@165
   103
        Add(new HDD.HDDGroup(settings));
moel@28
   104
moel@28
   105
      open = true;
moel@28
   106
    }
moel@167
   107
    
moel@28
   108
    public bool HDDEnabled {
moel@28
   109
      get { return hddEnabled; }
moel@167
   110
moel@167
   111
      [SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode = true)]
moel@28
   112
      set {
moel@28
   113
        if (open && value && !hddEnabled) {
moel@165
   114
          Add(new HDD.HDDGroup(settings));
moel@28
   115
        } else if (open && !value && hddEnabled) {
moel@28
   116
          List<IGroup> list = new List<IGroup>();
moel@28
   117
          foreach (IGroup group in groups)
moel@28
   118
            if (group is HDD.HDDGroup)
moel@28
   119
              list.Add(group);
moel@28
   120
          foreach (IGroup group in list)
moel@83
   121
            Remove(group);
moel@28
   122
        }
moel@28
   123
        hddEnabled = value;
moel@28
   124
      }
moel@28
   125
    }
moel@28
   126
moel@83
   127
    public IHardware[] Hardware {
moel@83
   128
      get {
moel@83
   129
        List<IHardware> list = new List<IHardware>();
moel@28
   130
        foreach (IGroup group in groups)
moel@28
   131
          foreach (IHardware hardware in group.Hardware)
moel@83
   132
            list.Add(hardware);
moel@83
   133
        return list.ToArray();
moel@28
   134
      }
moel@28
   135
    }
moel@28
   136
moel@167
   137
    private static void NewSection(TextWriter writer) {
moel@28
   138
      for (int i = 0; i < 8; i++)
moel@28
   139
        writer.Write("----------");
moel@28
   140
      writer.WriteLine();
moel@28
   141
      writer.WriteLine();
moel@28
   142
    }
moel@28
   143
moel@149
   144
    private int CompareSensor(ISensor a, ISensor b) {
moel@149
   145
      int c = a.SensorType.CompareTo(b.SensorType);
moel@149
   146
      if (c == 0)
moel@149
   147
        return a.Index.CompareTo(b.Index);
moel@149
   148
      else
moel@149
   149
        return c;
moel@149
   150
    }
moel@149
   151
moel@149
   152
    private void ReportHardwareSensorTree(IHardware hardware, TextWriter w,
moel@83
   153
      string space) {
moel@64
   154
      w.WriteLine("{0}|", space);
moel@83
   155
      w.WriteLine("{0}+-+ {1} ({2})",
moel@64
   156
        space, hardware.Name, hardware.Identifier);
moel@149
   157
      ISensor[] sensors = hardware.Sensors;
moel@149
   158
      Array.Sort<ISensor>(sensors, CompareSensor);
moel@149
   159
      foreach (ISensor sensor in sensors) {
moel@149
   160
        w.WriteLine("{0}|   +- {1}[{2}] : {3} : {4}",
moel@149
   161
          space, sensor.SensorType, sensor.Index, 
moel@64
   162
            string.Format(CultureInfo.InvariantCulture, "{0} : {1} : {2}",
moel@149
   163
            sensor.Value, sensor.Min, sensor.Max), sensor.Name);
moel@149
   164
      }
moel@149
   165
      foreach (IHardware subHardware in hardware.SubHardware)
moel@149
   166
        ReportHardwareSensorTree(subHardware, w, "|   ");
moel@149
   167
    }
moel@149
   168
moel@149
   169
    private void ReportHardwareParameterTree(IHardware hardware, TextWriter w,
moel@149
   170
      string space) {
moel@149
   171
      w.WriteLine("{0}|", space);
moel@149
   172
      w.WriteLine("{0}+-+ {1} ({2})",
moel@149
   173
        space, hardware.Name, hardware.Identifier);
moel@149
   174
      ISensor[] sensors = hardware.Sensors;
moel@149
   175
      Array.Sort<ISensor>(sensors, CompareSensor);
moel@149
   176
      foreach (ISensor sensor in sensors) {
moel@149
   177
        if (sensor.Parameters.Length > 0) {
moel@149
   178
          w.WriteLine("{0}|   +- {1}[{2}] : {3}",
moel@149
   179
            space, sensor.SensorType, sensor.Index, sensor.Name);
moel@149
   180
          foreach (IParameter parameter in sensor.Parameters) {
moel@149
   181
            w.WriteLine("{0}|      +- {1} : {2}",
moel@149
   182
              space, parameter.Name,
moel@149
   183
              string.Format(CultureInfo.InvariantCulture, "{0} : {1}",
moel@149
   184
                parameter.DefaultValue, parameter.Value));
moel@149
   185
          }
moel@64
   186
        }
moel@64
   187
      }
moel@64
   188
      foreach (IHardware subHardware in hardware.SubHardware)
moel@149
   189
        ReportHardwareParameterTree(subHardware, w, "|   ");
moel@64
   190
    }
moel@64
   191
moel@64
   192
    private void ReportHardware(IHardware hardware, TextWriter w) {
moel@64
   193
      string hardwareReport = hardware.GetReport();
moel@167
   194
      if (!string.IsNullOrEmpty(hardwareReport)) {
moel@64
   195
        NewSection(w);
moel@64
   196
        w.Write(hardwareReport);
moel@64
   197
      }
moel@64
   198
      foreach (IHardware subHardware in hardware.SubHardware)
moel@64
   199
        ReportHardware(subHardware, w);
moel@64
   200
    }
moel@64
   201
moel@83
   202
    public string GetReport() {
moel@28
   203
moel@166
   204
      using (StringWriter w = new StringWriter(CultureInfo.InvariantCulture)) {
moel@28
   205
moel@28
   206
        w.WriteLine();
moel@28
   207
        w.WriteLine("Open Hardware Monitor Report");
moel@28
   208
        w.WriteLine();
moel@28
   209
moel@83
   210
        Version version = typeof(Computer).Assembly.GetName().Version;
moel@83
   211
moel@28
   212
        NewSection(w);
moel@28
   213
        w.Write("Version: "); w.WriteLine(version.ToString());
moel@28
   214
        w.WriteLine();
moel@28
   215
moel@28
   216
        NewSection(w);
moel@119
   217
        w.Write("Common Language Runtime: ");
moel@119
   218
        w.WriteLine(Environment.Version.ToString());
moel@119
   219
        w.Write("Operating System: ");
moel@119
   220
        w.WriteLine(Environment.OSVersion.ToString());
moel@119
   221
        w.Write("Process Type: ");
moel@119
   222
        w.WriteLine(IntPtr.Size == 4 ? "32-Bit" : "64-Bit");
moel@119
   223
        w.WriteLine();
moel@119
   224
moel@119
   225
        NewSection(w);
moel@149
   226
        w.WriteLine("Sensors");
moel@149
   227
        w.WriteLine();
moel@28
   228
        foreach (IGroup group in groups) {
moel@64
   229
          foreach (IHardware hardware in group.Hardware)
moel@149
   230
            ReportHardwareSensorTree(hardware, w, "");
moel@149
   231
        }
moel@149
   232
        w.WriteLine();
moel@149
   233
moel@149
   234
        NewSection(w);
moel@149
   235
        w.WriteLine("Parameters");
moel@149
   236
        w.WriteLine();
moel@149
   237
        foreach (IGroup group in groups) {
moel@149
   238
          foreach (IHardware hardware in group.Hardware)
moel@149
   239
            ReportHardwareParameterTree(hardware, w, "");
moel@28
   240
        }
moel@28
   241
        w.WriteLine();
moel@28
   242
moel@28
   243
        foreach (IGroup group in groups) {
moel@28
   244
          string report = group.GetReport();
moel@167
   245
          if (!string.IsNullOrEmpty(report)) {
moel@28
   246
            NewSection(w);
moel@28
   247
            w.Write(report);
moel@28
   248
          }
moel@28
   249
moel@28
   250
          IHardware[] hardwareArray = group.Hardware;
moel@64
   251
          foreach (IHardware hardware in hardwareArray)
moel@64
   252
            ReportHardware(hardware, w);
moel@83
   253
moel@28
   254
        }
moel@83
   255
        return w.ToString();
moel@28
   256
      }
moel@28
   257
    }
moel@28
   258
moel@83
   259
    public void Close() {      
moel@28
   260
      if (!open)
moel@28
   261
        return;
moel@28
   262
moel@28
   263
      foreach (IGroup group in groups)
moel@28
   264
        group.Close();
moel@28
   265
      groups.Clear();
moel@28
   266
moel@167
   267
      WinRing0.Close();
moel@167
   268
moel@28
   269
      open = false;
moel@28
   270
    }
moel@28
   271
moel@28
   272
    public event HardwareEventHandler HardwareAdded;
moel@28
   273
    public event HardwareEventHandler HardwareRemoved;
moel@110
   274
moel@110
   275
    public void Accept(IVisitor visitor) {
moel@167
   276
      if (visitor == null)
moel@167
   277
        throw new ArgumentNullException("visitor");
moel@167
   278
      visitor.VisitComputer(this);
moel@110
   279
    }
moel@110
   280
moel@110
   281
    public void Traverse(IVisitor visitor) {
moel@110
   282
      foreach (IGroup group in groups)
moel@110
   283
        foreach (IHardware hardware in group.Hardware) 
moel@110
   284
          hardware.Accept(visitor);
moel@110
   285
    }
moel@165
   286
moel@165
   287
    private class Settings : ISettings {
moel@165
   288
moel@165
   289
      public bool Contains(string name) {
moel@165
   290
        return false;
moel@165
   291
      }
moel@165
   292
moel@166
   293
      public void SetValue(string name, string value) { }
moel@165
   294
moel@166
   295
      public string GetValue(string name, string value) {
moel@165
   296
        return value;
moel@165
   297
      }
moel@165
   298
moel@165
   299
      public void Remove(string name) { }
moel@165
   300
    }
moel@28
   301
  }
moel@28
   302
}