-rw-r--r-- | libopie/odevice.cpp | 41 |
1 files changed, 23 insertions, 18 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index cb7dd74..d78277f 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -1125,4 +1125,5 @@ void Zaurus::init ( ) | |||
1125 | 1125 | ||
1126 | QFile f ( "/proc/filesystems" ); | 1126 | QFile f ( "/proc/filesystems" ); |
1127 | QString model; | ||
1127 | 1128 | ||
1128 | if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { | 1129 | if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { |
@@ -1145,25 +1146,29 @@ void Zaurus::init ( ) | |||
1145 | } | 1146 | } |
1146 | 1147 | ||
1147 | f. setName ( "/proc/deviceinfo/product" ); | 1148 | f. setName ( "/proc/cpuinfo" ); |
1148 | if ( f. open ( IO_ReadOnly ) ) { | 1149 | if ( f. open ( IO_ReadOnly ) ) { |
1149 | QTextStream ts ( &f ); | 1150 | QTextStream ts ( &f ); |
1150 | QString model = ts. readLine ( ); | 1151 | QString line; |
1151 | f. close ( ); | 1152 | while( line = ts. readLine ( ) ) { |
1152 | 1153 | if ( line. left ( 8 ) == "Hardware" ) | |
1153 | d-> m_modelstr = QString("Zaurus ") + model; | 1154 | break; |
1154 | if ( model == "SL-5500" ) | 1155 | } |
1155 | d-> m_model = Model_Zaurus_SL5500; | 1156 | int loc = line. find ( ":" ); |
1156 | else if ( model == "SL-C700" ) | 1157 | if ( loc != -1 ) |
1157 | d-> m_model = Model_Zaurus_SLC700; | 1158 | model = line. mid ( loc + 2 ). simplifyWhitespace( ); |
1158 | else if ( model == "SL-A300" ) | ||
1159 | d-> m_model = Model_Zaurus_SLA300; | ||
1160 | else if ( model == "SL-B600" || model == "SL-5600" ) | ||
1161 | d-> m_model = Model_Zaurus_SLB600; | ||
1162 | else | ||
1163 | d-> m_model = Model_Zaurus_SL5000; | ||
1164 | } | 1159 | } |
1165 | else { | 1160 | |
1166 | d-> m_model = Model_Zaurus_SL5000; | 1161 | if ( model == "SHARP Corgi" ) { |
1167 | d-> m_modelstr = "Zaurus (model unknown)"; | 1162 | d-> m_model = Model_Zaurus_SLC700; |
1163 | d-> m_modelstr = "Zaurus SL-C700"; | ||
1164 | } else if ( model == "SHARP Poodle" ) { | ||
1165 | d-> m_model = Model_Zaurus_SLB600; | ||
1166 | d-> m_modelstr = "Zaurus SL-B500 or SL-5600"; | ||
1167 | } else if ( model = "Sharp-Collie" ) { | ||
1168 | d-> m_model = Model_Zaurus_SL5500; | ||
1169 | d-> m_modelstr = "Zaurus SL-5500 or SL-5000d"; | ||
1170 | } else { | ||
1171 | d-> m_model = Model_Zaurus_SL5500; | ||
1172 | d-> m_modelstr = "Zaurus (Model unknown)"; | ||
1168 | } | 1173 | } |
1169 | 1174 | ||