ReactOS 0.4.17-dev-357-ga8f14ff
jsstr.c File Reference
#include <assert.h>
#include "jscript.h"
#include "wine/debug.h"
Include dependency graph for jsstr.c:

Go to the source code of this file.

Macros

#define JSSTR_SHORT_STRING_LENGTH   8
 
#define JSSTR_MAX_ROPE_DEPTH   100
 
#define TMP_BUF_SIZE   256
 

Functions

const chardebugstr_jsstr (jsstr_t *str)
 
void jsstr_free (jsstr_t *str)
 
static void jsstr_init (jsstr_t *str, unsigned len, jsstr_tag_t tag)
 
jsstr_tjsstr_alloc_buf (unsigned len, WCHAR **buf)
 
jsstr_tjsstr_alloc_len (const WCHAR *buf, unsigned len)
 
static void jsstr_rope_extract (jsstr_rope_t *str, unsigned off, unsigned len, WCHAR *buf)
 
void jsstr_extract (jsstr_t *str, unsigned off, unsigned len, WCHAR *buf)
 
static int jsstr_cmp_str (jsstr_t *jsstr, const WCHAR *str, unsigned len)
 
static int ropes_cmp (jsstr_rope_t *left, jsstr_rope_t *right)
 
static const WCHARjsstr_try_flat (jsstr_t *str)
 
int jsstr_cmp (jsstr_t *str1, jsstr_t *str2)
 
jsstr_tjsstr_concat (jsstr_t *str1, jsstr_t *str2)
 
 C_ASSERT (sizeof(jsstr_heap_t)<=sizeof(jsstr_rope_t))
 
const WCHARjsstr_rope_flatten (jsstr_rope_t *str)
 
jsstr_tjsstr_nan (void)
 
jsstr_tjsstr_empty (void)
 
jsstr_tjsstr_undefined (void)
 
jsstr_tjsstr_null_bstr (void)
 
HRESULT jsstr_to_bstr (jsstr_t *str, BSTR *r)
 
BOOL init_strings (void)
 
void free_strings (void)
 

Variables

static jsstr_tempty_str
 
static jsstr_tnan_str
 
static jsstr_tundefined_str
 
static jsstr_tnull_bstr_str
 

Macro Definition Documentation

◆ JSSTR_MAX_ROPE_DEPTH

#define JSSTR_MAX_ROPE_DEPTH   100

Definition at line 35 of file jsstr.c.

◆ JSSTR_SHORT_STRING_LENGTH

#define JSSTR_SHORT_STRING_LENGTH   8

Definition at line 30 of file jsstr.c.

◆ TMP_BUF_SIZE

#define TMP_BUF_SIZE   256

Definition at line 157 of file jsstr.c.

Function Documentation

◆ C_ASSERT()

◆ debugstr_jsstr()

const char * debugstr_jsstr ( jsstr_t str)

Definition at line 37 of file jsstr.c.

38{
42}
const char * wine_dbg_sprintf(const char *format,...)
Definition: compat.c:296
GLenum GLuint GLenum GLsizei const GLchar * buf
Definition: glext.h:7751
GLint left
Definition: glext.h:7726
const char * debugstr_jsstr(jsstr_t *str)
Definition: jsstr.c:37
static jsstr_inline_t * jsstr_as_inline(jsstr_t *str)
Definition: jsstr.h:119
static unsigned jsstr_length(jsstr_t *str)
Definition: jsstr.h:55
static jsstr_heap_t * jsstr_as_heap(jsstr_t *str)
Definition: jsstr.h:124
static BOOL jsstr_is_heap(jsstr_t *str)
Definition: jsstr.h:70
static BOOL jsstr_is_inline(jsstr_t *str)
Definition: jsstr.h:65
static jsstr_rope_t * jsstr_as_rope(jsstr_t *str)
Definition: jsstr.h:129
#define debugstr_wn
Definition: kernel32.h:33
const WCHAR * str

Referenced by array_join(), debugstr_jsstr(), debugstr_jsval(), dump_instr_arg(), interp_obj_prop(), interp_regexp(), interp_str(), interp_throw_type(), JSGlobal_decodeURI(), JSGlobal_encodeURI(), String_prop_get(), and String_replace().

◆ free_strings()

void free_strings ( void  )

Definition at line 335 of file jsstr.c.

336{
337 if(empty_str)
339 if(nan_str)
341 if(undefined_str)
343 if(null_bstr_str)
345}
static jsstr_t * undefined_str
Definition: jsstr.c:284
static jsstr_t * null_bstr_str
Definition: jsstr.c:284
static jsstr_t * empty_str
Definition: jsstr.c:284
static jsstr_t * nan_str
Definition: jsstr.c:284
static void jsstr_release(jsstr_t *str)
Definition: jsstr.h:107

Referenced by DllMain().

◆ init_strings()

BOOL init_strings ( void  )

Definition at line 320 of file jsstr.c.

321{
322 WCHAR *ptr;
323
324 if(!(empty_str = jsstr_alloc_buf(0, &ptr)))
325 return FALSE;
326 if(!(nan_str = jsstr_alloc(L"NaN")))
327 return FALSE;
328 if(!(undefined_str = jsstr_alloc(L"undefined")))
329 return FALSE;
330 if(!(null_bstr_str = jsstr_alloc_buf(0, &ptr)))
331 return FALSE;
332 return TRUE;
333}
#define TRUE
Definition: types.h:120
#define FALSE
Definition: types.h:117
#define L(x)
Definition: resources.c:13
jsstr_t * jsstr_alloc_buf(unsigned len, WCHAR **buf)
Definition: jsstr.c:69
static jsstr_t * jsstr_alloc(const WCHAR *str)
Definition: jsstr.h:100
static PVOID ptr
Definition: dispmode.c:27
short WCHAR
Definition: pedump.c:58

Referenced by DllMain().

◆ jsstr_alloc_buf()

jsstr_t * jsstr_alloc_buf ( unsigned  len,
WCHAR **  buf 
)

◆ jsstr_alloc_len()

◆ jsstr_cmp()

int jsstr_cmp ( jsstr_t str1,
jsstr_t str2 
)

Definition at line 192 of file jsstr.c.

193{
194 unsigned len1 = jsstr_length(str1);
195 unsigned len2 = jsstr_length(str2);
196 const WCHAR *str;
197 int ret;
198
200 if(str) {
201 ret = jsstr_cmp_str(str1, str, min(len1, len2));
202 return ret || len1 == len2 ? ret : -1;
203 }
204
206 if(str) {
207 ret = jsstr_cmp_str(str2, str, min(len1, len2));
208 return ret || len1 == len2 ? -ret : 1;
209 }
210
212}
static int ropes_cmp(jsstr_rope_t *left, jsstr_rope_t *right)
Definition: jsstr.c:159
static int jsstr_cmp_str(jsstr_t *jsstr, const WCHAR *str, unsigned len)
Definition: jsstr.c:131
static const WCHAR * jsstr_try_flat(jsstr_t *str)
Definition: jsstr.c:185
#define min(a, b)
Definition: monoChain.cc:55
XML_HIDDEN void xmlParserErrors const char const xmlChar const xmlChar * str2
Definition: parser.h:35
XML_HIDDEN void xmlParserErrors const char const xmlChar * str1
Definition: parser.h:35

Referenced by jsstr_eq(), jsval_map_compare(), less_eval(), and sort_cmp().

◆ jsstr_cmp_str()

static int jsstr_cmp_str ( jsstr_t jsstr,
const WCHAR str,
unsigned  len 
)
static

Definition at line 131 of file jsstr.c.

132{
133 int ret;
134
135 switch(jsstr_tag(jsstr)) {
136 case JSSTR_INLINE:
137 ret = memcmp(jsstr_as_inline(jsstr)->buf, str, len*sizeof(WCHAR));
138 return ret || jsstr_length(jsstr) == len ? ret : 1;
139 case JSSTR_HEAP:
140 ret = memcmp(jsstr_as_heap(jsstr)->buf, str, len*sizeof(WCHAR));
141 return ret || jsstr_length(jsstr) == len ? ret : 1;
142 case JSSTR_ROPE: {
144 unsigned left_len = jsstr_length(rope->left);
145
146 ret = jsstr_cmp_str(rope->left, str, min(len, left_len));
147 if(ret || len <= left_len)
148 return ret;
149 return jsstr_cmp_str(rope->right, str+left_len, len-left_len);
150 }
151 }
152
153 assert(0);
154 return 0;
155}
Definition: _rope.h:1087
#define assert(_expr)
Definition: assert.h:32
_ACRTIMP int __cdecl memcmp(const void *, const void *, size_t)
Definition: string.c:2807
static jsstr_tag_t jsstr_tag(jsstr_t *str)
Definition: jsstr.h:60
@ JSSTR_HEAP
Definition: jsstr.h:51
@ JSSTR_ROPE
Definition: jsstr.h:52

Referenced by jsstr_cmp(), and jsstr_cmp_str().

◆ jsstr_concat()

jsstr_t * jsstr_concat ( jsstr_t str1,
jsstr_t str2 
)

Definition at line 214 of file jsstr.c.

215{
216 unsigned len1, len2;
217 jsstr_t *ret;
218 WCHAR *ptr;
219
220 len1 = jsstr_length(str1);
221 if(!len1)
222 return jsstr_addref(str2);
223
224 len2 = jsstr_length(str2);
225 if(!len2)
226 return jsstr_addref(str1);
227
228 if(len1 + len2 >= JSSTR_SHORT_STRING_LENGTH) {
229 unsigned depth, depth2;
231
233 depth2 = jsstr_is_rope(str2) ? jsstr_as_rope(str2)->depth : 0;
234 if(depth2 > depth)
235 depth = depth2;
236
238 if(len1+len2 > JSSTR_MAX_LENGTH)
239 return NULL;
240
241 rope = malloc(sizeof(*rope));
242 if(!rope)
243 return NULL;
244
245 jsstr_init(&rope->str, len1+len2, JSSTR_ROPE);
246 rope->left = jsstr_addref(str1);
247 rope->right = jsstr_addref(str2);
248 rope->depth = depth;
249 return &rope->str;
250 }
251 }
252
253 ret = jsstr_alloc_buf(len1+len2, &ptr);
254 if(!ret)
255 return NULL;
256
258 jsstr_flush(str2, ptr+len1);
259 return ret;
260
261}
GLint GLint GLsizei GLsizei GLsizei depth
Definition: gl.h:1546
#define JSSTR_SHORT_STRING_LENGTH
Definition: jsstr.c:30
#define JSSTR_MAX_ROPE_DEPTH
Definition: jsstr.c:35
static jsstr_t * jsstr_addref(jsstr_t *str)
Definition: jsstr.h:113
static BOOL jsstr_is_rope(jsstr_t *str)
Definition: jsstr.h:75
static unsigned jsstr_flush(jsstr_t *str, WCHAR *buf)
Definition: jsstr.h:145
unsigned depth
Definition: jsstr.h:94

Referenced by interp_add(), and String_concat().

◆ jsstr_empty()

◆ jsstr_extract()

void jsstr_extract ( jsstr_t str,
unsigned  off,
unsigned  len,
WCHAR buf 
)

Definition at line 113 of file jsstr.c.

114{
115 switch(jsstr_tag(str)) {
116 case JSSTR_INLINE:
117 memcpy(buf, jsstr_as_inline(str)->buf+off, len*sizeof(WCHAR));
118 return;
119 case JSSTR_HEAP:
120 memcpy(buf, jsstr_as_heap(str)->buf+off, len*sizeof(WCHAR));
121 return;
122 case JSSTR_ROPE:
123#ifdef __REACTOS__
125#else
127#endif
128 }
129}
static void jsstr_rope_extract(jsstr_rope_t *str, unsigned off, unsigned len, WCHAR *buf)
Definition: jsstr.c:98

Referenced by JSON_stringify(), jsstr_rope_extract(), jsstr_substr(), and String_charCodeAt().

◆ jsstr_free()

void jsstr_free ( jsstr_t str)

Definition at line 44 of file jsstr.c.

45{
46 switch(jsstr_tag(str)) {
47 case JSSTR_HEAP:
49 break;
50 case JSSTR_ROPE: {
52 jsstr_release(rope->left);
53 jsstr_release(rope->right);
54 break;
55 }
56 case JSSTR_INLINE:
57 break;
58 }
59
60 free(str);
61}
#define free
Definition: debug_ros.c:5

Referenced by jsstr_release().

◆ jsstr_init()

static void jsstr_init ( jsstr_t str,
unsigned  len,
jsstr_tag_t  tag 
)
inlinestatic

Definition at line 63 of file jsstr.c.

64{
65 str->length_flags = len << JSSTR_LENGTH_SHIFT | tag;
66 str->ref = 1;
67}
#define JSSTR_LENGTH_SHIFT
Definition: jsstr.h:41
Definition: ecma_167.h:138

Referenced by jsstr_alloc_buf(), and jsstr_concat().

◆ jsstr_nan()

◆ jsstr_null_bstr()

jsstr_t * jsstr_null_bstr ( void  )

Definition at line 301 of file jsstr.c.

302{
304}

Referenced by variant_to_jsval().

◆ jsstr_rope_extract()

static void jsstr_rope_extract ( jsstr_rope_t str,
unsigned  off,
unsigned  len,
WCHAR buf 
)
static

Definition at line 98 of file jsstr.c.

99{
100 unsigned left_len = jsstr_length(str->left);
101
102 if(left_len <= off) {
103 jsstr_extract(str->right, off-left_len, len, buf);
104 }else if(left_len >= len+off) {
105 jsstr_extract(str->left, off, len, buf);
106 }else {
107 left_len -= off;
108 jsstr_extract(str->left, off, left_len, buf);
109 jsstr_extract(str->right, 0, len-left_len, buf+left_len);
110 }
111}
void jsstr_extract(jsstr_t *str, unsigned off, unsigned len, WCHAR *buf)
Definition: jsstr.c:113

Referenced by jsstr_extract(), and ropes_cmp().

◆ jsstr_rope_flatten()

const WCHAR * jsstr_rope_flatten ( jsstr_rope_t str)

Definition at line 265 of file jsstr.c.

266{
267 WCHAR *buf;
268
269 buf = malloc((jsstr_length(&str->str)+1) * sizeof(WCHAR));
270 if(!buf)
271 return NULL;
272
273 jsstr_flush(str->left, buf);
274 jsstr_flush(str->right, buf+jsstr_length(str->left));
275 buf[jsstr_length(&str->str)] = 0;
276
277 /* Trasform to heap string */
278 jsstr_release(str->left);
279 jsstr_release(str->right);
280 str->str.length_flags |= JSSTR_FLAG_FLAT;
281 return jsstr_as_heap(&str->str)->buf = buf;
282}
#define JSSTR_FLAG_FLAT
Definition: jsstr.h:46
WCHAR * buf
Definition: jsstr.h:87

Referenced by jsstr_flatten().

◆ jsstr_to_bstr()

HRESULT jsstr_to_bstr ( jsstr_t str,
BSTR r 
)

Definition at line 306 of file jsstr.c.

307{
308 if(str == null_bstr_str) {
309 *r = NULL;
310 return S_OK;
311 }
312
314 return E_OUTOFMEMORY;
315
316 jsstr_flush(str, *r);
317 return S_OK;
318}
#define E_OUTOFMEMORY
Definition: ddrawi.h:100
GLdouble GLdouble GLdouble r
Definition: gl.h:2055
#define S_OK
Definition: intsafe.h:52
BSTR WINAPI SysAllocStringLen(const OLECHAR *str, unsigned int len)
Definition: oleaut.c:339

Referenced by JScriptError_GetExceptionInfo(), JScriptError_GetSourceLineText(), jsval_to_variant(), and variant_change_type().

◆ jsstr_try_flat()

static const WCHAR * jsstr_try_flat ( jsstr_t str)
inlinestatic

Definition at line 185 of file jsstr.c.

186{
189 : NULL;
190}
WCHAR buf[]
Definition: jsstr.h:82

Referenced by jsstr_cmp().

◆ jsstr_undefined()

◆ ropes_cmp()

static int ropes_cmp ( jsstr_rope_t left,
jsstr_rope_t right 
)
static

Definition at line 159 of file jsstr.c.

160{
161 WCHAR left_buf[TMP_BUF_SIZE], right_buf[TMP_BUF_SIZE];
162 unsigned left_len = jsstr_length(&left->str);
163 unsigned right_len = jsstr_length(&right->str);
164 unsigned cmp_off = 0, cmp_size;
165 int ret;
166
167 /* FIXME: We can avoid temporary buffers here. */
168 while(cmp_off < min(left_len, right_len)) {
169 cmp_size = min(left_len, right_len) - cmp_off;
170 if(cmp_size > TMP_BUF_SIZE)
171 cmp_size = TMP_BUF_SIZE;
172
173 jsstr_rope_extract(left, cmp_off, cmp_size, left_buf);
174 jsstr_rope_extract(right, cmp_off, cmp_size, right_buf);
175 ret = memcmp(left_buf, right_buf, cmp_size);
176 if(ret)
177 return ret;
178
179 cmp_off += cmp_size;
180 }
181
182 return left_len - right_len;
183}
GLdouble GLdouble right
Definition: glext.h:10859
#define TMP_BUF_SIZE
Definition: jsstr.c:157

Referenced by jsstr_cmp().

Variable Documentation

◆ empty_str

jsstr_t* empty_str
static

Definition at line 284 of file jsstr.c.

Referenced by free_strings(), init_strings(), and jsstr_empty().

◆ nan_str

jsstr_t * nan_str
static

Definition at line 284 of file jsstr.c.

Referenced by free_strings(), init_strings(), and jsstr_nan().

◆ null_bstr_str

jsstr_t * null_bstr_str
static

Definition at line 284 of file jsstr.c.

Referenced by free_strings(), init_strings(), jsstr_null_bstr(), and jsstr_to_bstr().

◆ undefined_str

jsstr_t * undefined_str
static

Definition at line 284 of file jsstr.c.

Referenced by free_strings(), init_strings(), and jsstr_undefined().