author | zecke <zecke> | 2004-11-15 14:36:25 (UTC) |
---|---|---|
committer | zecke <zecke> | 2004-11-15 14:36:25 (UTC) |
commit | 2423fe1ba41caf6977afaf7df3156522b54db819 (patch) (unidiff) | |
tree | c6b6a8952c41c9677150a281c5698655a18e652d | |
parent | 5e6ce0ba567dd9c8ae33353fcf1d0554b34241e8 (diff) | |
download | opie-2423fe1ba41caf6977afaf7df3156522b54db819.zip opie-2423fe1ba41caf6977afaf7df3156522b54db819.tar.gz opie-2423fe1ba41caf6977afaf7df3156522b54db819.tar.bz2 |
-Safe the replay via Global::applicationFileName
-do not use char casts to go from string to char* but
use QFile::encodeName so it works for non latin1 people as well
-rw-r--r-- | noncore/games/sfcave/sfcave.cpp | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/noncore/games/sfcave/sfcave.cpp b/noncore/games/sfcave/sfcave.cpp index 5dca427..d5aa38a 100644 --- a/noncore/games/sfcave/sfcave.cpp +++ b/noncore/games/sfcave/sfcave.cpp | |||
@@ -1,31 +1,32 @@ | |||
1 | #include <stdio.h> | 1 | #include <stdio.h> |
2 | #include <stdlib.h> | 2 | #include <stdlib.h> |
3 | #include <math.h> | 3 | #include <math.h> |
4 | #include <time.h> | 4 | #include <time.h> |
5 | 5 | ||
6 | #include <opie2/oapplicationfactory.h> | 6 | #include <opie2/oapplicationfactory.h> |
7 | #include <qpe/config.h> | 7 | #include <qpe/config.h> |
8 | #include <qpe/global.h> | ||
8 | 9 | ||
9 | #include <qapplication.h> | 10 | #include <qapplication.h> |
10 | #include <qdir.h> | 11 | #include <qdir.h> |
11 | 12 | ||
12 | #include "helpwindow.h" | 13 | #include "helpwindow.h" |
13 | #include "sfcave.h" | 14 | #include "sfcave.h" |
14 | 15 | ||
15 | #define CAPTION "SFCave 1.13 by AndyQ" | 16 | #define CAPTION "SFCave 1.13 by AndyQ" |
16 | 17 | ||
17 | #define UP_THRUST 0.6 | 18 | #define UP_THRUST 0.6 |
18 | #define NO_THRUST 0.8 | 19 | #define NO_THRUST 0.8 |
19 | #define MAX_DOWN_THRUST 4.0 | 20 | #define MAX_DOWN_THRUST 4.0 |
20 | #define MAX_UP_THRUST -3.5 | 21 | #define MAX_UP_THRUST -3.5 |
21 | 22 | ||
22 | // States | 23 | // States |
23 | #define STATE_BOSS 0 | 24 | #define STATE_BOSS 0 |
24 | #define STATE_RUNNING 1 | 25 | #define STATE_RUNNING 1 |
25 | #define STATE_CRASHING 2 | 26 | #define STATE_CRASHING 2 |
26 | #define STATE_CRASHED 3 | 27 | #define STATE_CRASHED 3 |
27 | #define STATE_NEWGAME 4 | 28 | #define STATE_NEWGAME 4 |
28 | #define STATE_MENU 5 | 29 | #define STATE_MENU 5 |
29 | #define STATE_REPLAY 6 | 30 | #define STATE_REPLAY 6 |
30 | 31 | ||
31 | // Menus | 32 | // Menus |
@@ -122,51 +123,49 @@ int SFCave::flyHardScores[7][3] = { { 0, 20, 5 }, | |||
122 | { 100, 150, -2 }, | 123 | { 100, 150, -2 }, |
123 | { 150, 300, -5 }, | 124 | { 150, 300, -5 }, |
124 | { -1, -1, -1 } }; | 125 | { -1, -1, -1 } }; |
125 | 126 | ||
126 | int SFCave::initialGateGaps[] = { 75, 50, 25 }; | 127 | int SFCave::initialGateGaps[] = { 75, 50, 25 }; |
127 | 128 | ||
128 | 129 | ||
129 | #define FLYSCORES( x, y ) (*(flyScores + ((x)*3) + y)) | 130 | #define FLYSCORES( x, y ) (*(flyScores + ((x)*3) + y)) |
130 | bool movel; | 131 | bool movel; |
131 | 132 | ||
132 | 133 | ||
133 | OPIE_EXPORT_APP( Opie::Core::OApplicationFactory<SFCave> ) | 134 | OPIE_EXPORT_APP( Opie::Core::OApplicationFactory<SFCave> ) |
134 | 135 | ||
135 | SFCave :: SFCave( QWidget *w, const char *name, WFlags fl ) | 136 | SFCave :: SFCave( QWidget *w, const char *name, WFlags fl ) |
136 | : QMainWindow( w, name, fl ) | 137 | : QMainWindow( w, name, fl ) |
137 | 138 | ||
138 | { | 139 | { |
139 | showMaximized(); | 140 | showMaximized(); |
140 | movel = true; | 141 | movel = true; |
141 | int spd = 3; | 142 | int spd = 3; |
142 | 143 | ||
143 | 144 | ||
144 | replayIt = 0; | 145 | replayIt = 0; |
145 | 146 | ||
146 | replayFile = QDir::home().path(); | 147 | replayFile = Global::applicationFileName("sfcave", "replay"); |
147 | replayFile += "/sfcave.replay"; | ||
148 | printf( "%s\n", (const char *)replayFile ); | ||
149 | 148 | ||
150 | sWidth = width(); | 149 | sWidth = width(); |
151 | sHeight = height(); | 150 | sHeight = height(); |
152 | segSize = sWidth/(MAPSIZE-1)+1; | 151 | segSize = sWidth/(MAPSIZE-1)+1; |
153 | 152 | ||
154 | currentMenuNr = 0; | 153 | currentMenuNr = 0; |
155 | currentGameType = 0; | 154 | currentGameType = 0; |
156 | currentGameDifficulty = 0; | 155 | currentGameDifficulty = 0; |
157 | 156 | ||
158 | setCaption( CAPTION ); | 157 | setCaption( CAPTION ); |
159 | showScoreZones = false; | 158 | showScoreZones = false; |
160 | 159 | ||
161 | #ifdef QWS | 160 | #ifdef QWS |
162 | Config cfg( "sfcave" ); | 161 | Config cfg( "sfcave" ); |
163 | cfg.setGroup( "settings" ); | 162 | cfg.setGroup( "settings" ); |
164 | QString key = "highScore_"; | 163 | QString key = "highScore_"; |
165 | 164 | ||
166 | for ( int i = 0 ; i < 3 ; ++i ) | 165 | for ( int i = 0 ; i < 3 ; ++i ) |
167 | { | 166 | { |
168 | for ( int j = 0 ; j < 3 ; ++j ) | 167 | for ( int j = 0 ; j < 3 ; ++j ) |
169 | highestScore[i][j] = cfg.readNumEntry( key + gameTypes[i] + "_" + dificultyOption[j], 0 ); | 168 | highestScore[i][j] = cfg.readNumEntry( key + gameTypes[i] + "_" + dificultyOption[j], 0 ); |
170 | } | 169 | } |
171 | 170 | ||
172 | currentGameType = cfg.readNumEntry( "gameType", 0 ); | 171 | currentGameType = cfg.readNumEntry( "gameType", 0 ); |
@@ -903,128 +902,128 @@ void SFCave :: keyReleaseEvent( QKeyEvent *e ) | |||
903 | e->ignore(); | 902 | e->ignore(); |
904 | break; | 903 | break; |
905 | } | 904 | } |
906 | } | 905 | } |
907 | 906 | ||
908 | } | 907 | } |
909 | 908 | ||
910 | 909 | ||
911 | void SFCave :: saveScore() | 910 | void SFCave :: saveScore() |
912 | { | 911 | { |
913 | #ifdef QWS | 912 | #ifdef QWS |
914 | Config cfg( "sfcave" ); | 913 | Config cfg( "sfcave" ); |
915 | cfg.setGroup( "settings" ); | 914 | cfg.setGroup( "settings" ); |
916 | QString key = "highScore_"; | 915 | QString key = "highScore_"; |
917 | 916 | ||
918 | cfg.writeEntry( key + gameTypes[currentGameType] + "_" + dificultyOption[currentGameDifficulty], highestScore[currentGameType][currentGameDifficulty] ); | 917 | cfg.writeEntry( key + gameTypes[currentGameType] + "_" + dificultyOption[currentGameDifficulty], highestScore[currentGameType][currentGameDifficulty] ); |
919 | key += CURRENT_GAME_TYPE; | 918 | key += CURRENT_GAME_TYPE; |
920 | cfg.writeEntry( key, highestScore[currentGameType] ); | 919 | cfg.writeEntry( key, highestScore[currentGameType] ); |
921 | #endif | 920 | #endif |
922 | } | 921 | } |
923 | 922 | ||
924 | void SFCave :: saveReplay() | 923 | void SFCave :: saveReplay() |
925 | { | 924 | { |
926 | FILE *out; | 925 | FILE *out; |
927 | out = fopen( (const char *)replayFile, "w" ); | 926 | out = fopen( QFile::encodeName(replayFile).data(), "w" ); |
928 | if ( !out ) | 927 | if ( !out ) |
929 | { | 928 | { |
930 | printf( "Couldn't write to /home/root/sfcave.replay\n" ); | 929 | printf( "Couldn't write to %s\n", QFile::encodeName(replayFile).data() ); |
931 | return; | 930 | return; |
932 | } | 931 | } |
933 | 932 | ||
934 | // Build up string of values | 933 | // Build up string of values |
935 | // Format is:: <landscape seed> <game type> <difficulty> <framenr> <framenr>....... | 934 | // Format is:: <landscape seed> <game type> <difficulty> <framenr> <framenr>....... |
936 | QString val; | 935 | QString val; |
937 | val.sprintf( "%d %d %d ", currentSeed, currentGameType, currentGameDifficulty ); | 936 | val.sprintf( "%d %d %d ", currentSeed, currentGameType, currentGameDifficulty ); |
938 | 937 | ||
939 | QListIterator<int> it( replayList ); | 938 | QListIterator<int> it( replayList ); |
940 | while( it.current() ) | 939 | while( it.current() ) |
941 | { | 940 | { |
942 | QString tmp; | 941 | QString tmp; |
943 | tmp.sprintf( "%d ", (*it.current()) ); | 942 | tmp.sprintf( "%d ", (*it.current()) ); |
944 | val += tmp; | 943 | val += tmp; |
945 | 944 | ||
946 | ++it; | 945 | ++it; |
947 | } | 946 | } |
948 | val += "\n"; | 947 | val += "\n"; |
949 | 948 | ||
950 | QString line; | 949 | QString line; |
951 | line.sprintf( "%d\n", val.length() ); | 950 | line.sprintf( "%d\n", val.length() ); |
952 | fwrite( (const char *)line, 1, line.length(), out ); | 951 | fwrite( (const char *)line, 1, line.length(), out ); |
953 | 952 | ||
954 | fwrite( (const char *)val, 1, val.length(), out ); | 953 | fwrite( (const char *)val, 1, val.length(), out ); |
955 | 954 | ||
956 | fclose( out ); | 955 | fclose( out ); |
957 | 956 | ||
958 | printf( "Replay saved to %s\n", (const char *)replayFile ); | 957 | printf( "Replay saved to %s\n", QFile::encodeName(replayFile).data() ); |
959 | 958 | ||
960 | } | 959 | } |
961 | 960 | ||
962 | void SFCave :: loadReplay() | 961 | void SFCave :: loadReplay() |
963 | { | 962 | { |
964 | FILE *in = fopen( (const char *)replayFile, "r" ); | 963 | FILE *in = fopen( QFile::encodeName(replayFile).data() , "r" ); |
965 | 964 | ||
966 | if ( in == 0 ) | 965 | if ( in == 0 ) |
967 | { | 966 | { |
968 | printf( "Couldn't load replay file!\n" ); | 967 | printf( "Couldn't load replay file!\n" ); |
969 | return; | 968 | return; |
970 | } | 969 | } |
971 | 970 | ||
972 | // Read next line - contains the size of the options | 971 | // Read next line - contains the size of the options |
973 | char line[10+1]; | 972 | char line[10+1]; |
974 | fgets( line, 10, in ); | 973 | fgets( line, 10, in ); |
975 | 974 | ||
976 | int length = -1; | 975 | int length = -1; |
977 | sscanf( line, "%d", &length ); | 976 | sscanf( line, "%d", &length ); |
978 | char *data = new char[length+1]; | 977 | char *data = new char[length+1]; |
979 | 978 | ||
980 | fread( data, 1, length, in ); | 979 | fread( data, 1, length, in ); |
981 | // printf( "data - %s", data ); | 980 | // printf( "data - %s", data ); |
982 | 981 | ||
983 | QString sep = " "; | 982 | QString sep = " "; |
984 | QStringList list = QStringList::split( sep, QString( data ) ); | 983 | QStringList list = QStringList::split( sep, QString( data ) ); |
985 | 984 | ||
986 | // print it out | 985 | // print it out |
987 | QStringList::Iterator it = list.begin(); | 986 | QStringList::Iterator it = list.begin(); |
988 | currentSeed = (*it).toInt(); | 987 | currentSeed = (*it).toInt(); |
989 | ++it; | 988 | ++it; |
990 | currentGameType = (*it).toInt(); | 989 | currentGameType = (*it).toInt(); |
991 | ++it; | 990 | ++it; |
992 | currentGameDifficulty = (*it).toInt(); | 991 | currentGameDifficulty = (*it).toInt(); |
993 | ++it; | 992 | ++it; |
994 | 993 | ||
995 | replayList.clear(); | 994 | replayList.clear(); |
996 | for ( ; it != list.end(); ++it ) | 995 | for ( ; it != list.end(); ++it ) |
997 | { | 996 | { |
998 | int v = (*it).toInt(); | 997 | int v = (*it).toInt(); |
999 | replayList.append( new int( v ) ); | 998 | replayList.append( new int( v ) ); |
1000 | } | 999 | } |
1001 | 1000 | ||
1002 | delete data; | 1001 | delete data; |
1003 | 1002 | ||
1004 | fclose( in ); | 1003 | fclose( in ); |
1005 | 1004 | ||
1006 | printf( "Replay loaded from %s\n", (const char *)replayFile ); | 1005 | printf( "Replay loaded from %s\n", QFile::encodeName(replayFile).data() ); |
1007 | } | 1006 | } |
1008 | 1007 | ||
1009 | 1008 | ||
1010 | //--------------- MENU CODE --------------------- | 1009 | //--------------- MENU CODE --------------------- |
1011 | void SFCave :: handleMenuKeys( QKeyEvent *e ) | 1010 | void SFCave :: handleMenuKeys( QKeyEvent *e ) |
1012 | { | 1011 | { |
1013 | switch( e->key() ) | 1012 | switch( e->key() ) |
1014 | { | 1013 | { |
1015 | case Qt::Key_Down: | 1014 | case Qt::Key_Down: |
1016 | currentMenuOption[currentMenuNr] ++; | 1015 | currentMenuOption[currentMenuNr] ++; |
1017 | if ( menuOptions[currentMenuNr][currentMenuOption[currentMenuNr]] == "" ) | 1016 | if ( menuOptions[currentMenuNr][currentMenuOption[currentMenuNr]] == "" ) |
1018 | currentMenuOption[currentMenuNr] = 0; | 1017 | currentMenuOption[currentMenuNr] = 0; |
1019 | break; | 1018 | break; |
1020 | case Qt::Key_Up: | 1019 | case Qt::Key_Up: |
1021 | currentMenuOption[currentMenuNr] --; | 1020 | currentMenuOption[currentMenuNr] --; |
1022 | if ( currentMenuOption[currentMenuNr] < 0 ) | 1021 | if ( currentMenuOption[currentMenuNr] < 0 ) |
1023 | currentMenuOption[currentMenuNr] = nrMenuOptions[currentMenuNr]-1; | 1022 | currentMenuOption[currentMenuNr] = nrMenuOptions[currentMenuNr]-1; |
1024 | break; | 1023 | break; |
1025 | 1024 | ||
1026 | case Qt::Key_Left: | 1025 | case Qt::Key_Left: |
1027 | if ( currentMenuNr == MENU_OPTIONS_MENU ) | 1026 | if ( currentMenuNr == MENU_OPTIONS_MENU ) |
1028 | { | 1027 | { |
1029 | if ( currentMenuOption[currentMenuNr] == MENU_GAME_TYPE ) | 1028 | if ( currentMenuOption[currentMenuNr] == MENU_GAME_TYPE ) |
1030 | { | 1029 | { |