Overview
Context
Changes
Modified src/OFString.m
from [95256ec388]
to [0e48ad1696].
︙ | | |
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
|
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
|
-
-
+
-
-
-
-
-
+
-
-
-
|
if (length == 0)
return ret;
pool = objc_autoreleasePoolPush();
characters = [self characters];
#if !defined(_WIN32) && !defined(__DJGPP__)
if (characters[length - 1] == OF_PATH_DELIMITER)
if (OF_IS_PATH_DELIMITER(characters[length - 1]))
#else
if (characters[length - 1] == '/' || characters[length - 1] == '\\')
#endif
length--;
for (i = 0; i < length; i++) {
#if !defined(_WIN32) && !defined(__DJGPP__)
if (characters[i] == OF_PATH_DELIMITER) {
if (OF_IS_PATH_DELIMITER(characters[i])) {
#else
if (characters[i] == '/' || characters[i] == '\\') {
#endif
[ret addObject: [self substringWithRange:
of_range(last, i - last)]];
last = i + 1;
}
}
|
︙ | | |
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
|
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
|
-
-
+
-
-
-
-
-
+
-
-
-
|
if (length == 0)
return @"";
pool = objc_autoreleasePoolPush();
characters = [self characters];
#if !defined(_WIN32) && !defined(__DJGPP__)
if (characters[length - 1] == OF_PATH_DELIMITER)
if (OF_IS_PATH_DELIMITER(characters[length - 1]))
#else
if (characters[length - 1] == '/' || characters[length - 1] == '\\')
#endif
length--;
for (i = length - 1; i >= 0; i--) {
#if !defined(_WIN32) && !defined(__DJGPP__)
if (characters[i] == OF_PATH_DELIMITER) {
if (OF_IS_PATH_DELIMITER(characters[i])) {
#else
if (characters[i] == '/' || characters[i] == '\\') {
#endif
i++;
break;
}
}
objc_autoreleasePoolPop(pool);
|
︙ | | |
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
|
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
|
-
-
+
-
-
-
-
-
+
-
-
-
-
-
+
-
-
-
|
if (length == 0)
return @"";
pool = objc_autoreleasePoolPush();
characters = [self characters];
#if !defined(_WIN32) && !defined(__DJGPP__)
if (characters[length - 1] == OF_PATH_DELIMITER)
if (OF_IS_PATH_DELIMITER(characters[length - 1]))
#else
if (characters[length - 1] == '/' || characters[length - 1] == '\\')
#endif
length--;
if (length == 0) {
objc_autoreleasePoolPop(pool);
return [self substringWithRange: of_range(0, 1)];
}
for (i = length - 1; i >= 1; i--) {
#if !defined(_WIN32) && !defined(__DJGPP__)
if (characters[i] == OF_PATH_DELIMITER) {
if (OF_IS_PATH_DELIMITER(characters[i])) {
#else
if (characters[i] == '/' || characters[i] == '\\') {
#endif
objc_autoreleasePoolPop(pool);
return [self substringWithRange: of_range(0, i)];
}
}
#if !defined(_WIN32) && !defined(__DJGPP__)
if (characters[0] == OF_PATH_DELIMITER) {
if (OF_IS_PATH_DELIMITER(characters[0])) {
#else
if (characters[0] == '/' || characters[0] == '\\') {
#endif
objc_autoreleasePoolPop(pool);
return [self substringWithRange: of_range(0, 1)];
}
objc_autoreleasePoolPop(pool);
return OF_PATH_CURRENT_DIRECTORY;
|
︙ | | |
Modified src/OFString_UTF8.m
from [458af69b3f]
to [cb1d0ad5b1].
︙ | | |
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
|
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
|
-
-
-
-
-
+
-
-
-
+
-
-
-
|
ret = [OFMutableArray array];
if (pathCStringLength == 0)
return ret;
pool = objc_autoreleasePoolPush();
#if !defined(_WIN32) && !defined(__DJGPP__)
if (_s->cString[pathCStringLength - 1] == OF_PATH_DELIMITER)
#else
if (_s->cString[pathCStringLength - 1] == '/' ||
_s->cString[pathCStringLength - 1] == '\\')
if (OF_IS_PATH_DELIMITER(_s->cString[pathCStringLength - 1]))
#endif
pathCStringLength--;
for (i = 0; i < pathCStringLength; i++) {
#if !defined(_WIN32) && !defined(__DJGPP__)
if (_s->cString[i] == OF_PATH_DELIMITER) {
if (OF_IS_PATH_DELIMITER(_s->cString[i])) {
#else
if (_s->cString[i] == '/' || _s->cString[i] == '\\') {
#endif
[ret addObject:
[OFString stringWithUTF8String: _s->cString + last
length: i - last]];
last = i + 1;
}
}
|
︙ | | |
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
|
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
|
-
-
-
-
-
+
-
-
-
+
-
-
-
|
{
size_t pathCStringLength = _s->cStringLength;
ssize_t i;
if (pathCStringLength == 0)
return @"";
#if !defined(_WIN32) && !defined(__DJGPP__)
if (_s->cString[pathCStringLength - 1] == OF_PATH_DELIMITER)
#else
if (_s->cString[pathCStringLength - 1] == '/' ||
_s->cString[pathCStringLength - 1] == '\\')
if (OF_IS_PATH_DELIMITER(_s->cString[pathCStringLength - 1]))
#endif
pathCStringLength--;
for (i = pathCStringLength - 1; i >= 0; i--) {
#if !defined(_WIN32) && !defined(__DJGPP__)
if (_s->cString[i] == OF_PATH_DELIMITER) {
if (OF_IS_PATH_DELIMITER(_s->cString[i])) {
#else
if (_s->cString[i] == '/' || _s->cString[i] == '\\') {
#endif
i++;
break;
}
}
/*
* Only one component, but the trailing delimiter might have been
|
︙ | | |
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
|
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
|
-
-
-
-
-
+
-
-
-
+
-
-
-
-
-
+
-
-
-
|
- (OFString*)stringByDeletingLastPathComponent
{
size_t i, pathCStringLength = _s->cStringLength;
if (pathCStringLength == 0)
return @"";
#if !defined(_WIN32) && !defined(__DJGPP__)
if (_s->cString[pathCStringLength - 1] == OF_PATH_DELIMITER)
#else
if (_s->cString[pathCStringLength - 1] == '/' ||
_s->cString[pathCStringLength - 1] == '\\')
if (OF_IS_PATH_DELIMITER(_s->cString[pathCStringLength - 1]))
#endif
pathCStringLength--;
if (pathCStringLength == 0)
return [OFString stringWithUTF8String: _s->cString
length: 1];
for (i = pathCStringLength - 1; i >= 1; i--)
#if !defined(_WIN32) && !defined(__DJGPP__)
if (_s->cString[i] == OF_PATH_DELIMITER)
if (OF_IS_PATH_DELIMITER(_s->cString[i]))
#else
if (_s->cString[i] == '/' || _s->cString[i] == '\\')
#endif
return [OFString stringWithUTF8String: _s->cString
length: i];
#if !defined(_WIN32) && !defined(__DJGPP__)
if (_s->cString[0] == OF_PATH_DELIMITER)
if (OF_IS_PATH_DELIMITER(_s->cString[0]))
#else
if (_s->cString[0] == '/' || _s->cString[0] == '\\')
#endif
return [OFString stringWithUTF8String: _s->cString
length: 1];
return @".";
}
- (const of_unichar_t*)characters
|
︙ | | |
Modified src/macros.h
from [dcc14d0966]
to [4a09bf3501].
︙ | | |
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
|
+
+
|
__FILE__ ":%d:\n" #cond "\n", __LINE__); \
abort(); \
}
#if !defined(_WIN32) && !defined(__DJGPP__)
# define OF_PATH_DELIMITER '/'
# define OF_PATH_DELIMITER_STRING @"/"
# define OF_IS_PATH_DELIMITER(c) (c == '/')
#else
# define OF_PATH_DELIMITER '\\'
# define OF_PATH_DELIMITER_STRING @"\\"
# define OF_IS_PATH_DELIMITER(c) (c == '\\' || c == '/')
#endif
#define OF_PATH_CURRENT_DIRECTORY @"."
#define OF_PATH_PARENT_DIRECTORY @".."
extern id objc_getProperty(id, SEL, ptrdiff_t, BOOL);
extern void objc_setProperty(id, SEL, ptrdiff_t, id, BOOL, signed char);
|
︙ | | |