internal/gcce/src/gcce-load.cpp
author hgs
Tue, 02 Nov 2010 19:23:22 +0530
changeset 79 564bc7b7ad27
permissions -rw-r--r--
201043
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
79
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* ==============================================================================
hgs
parents:
diff changeset
     3
*  Name        : gcce-validate.c
hgs
parents:
diff changeset
     4
*  Part of     : internal/gcce
hgs
parents:
diff changeset
     5
*  Description : This is a test program to test the cross linking of openc libraries with
hgs
parents:
diff changeset
     6
*  programs compiled using the gcce compiler
hgs
parents:
diff changeset
     7
Copyright © 2006 Nokia Corporation
hgs
parents:
diff changeset
     8
All rights reserved.
hgs
parents:
diff changeset
     9
Redistribution and use in source and binary forms, with or without 
hgs
parents:
diff changeset
    10
modification, are permitted provided that the following conditions are met:
hgs
parents:
diff changeset
    11
 * Redistributions of source code must retain the above copyright notice, this 
hgs
parents:
diff changeset
    12
   list of conditions and the following disclaimer. 
hgs
parents:
diff changeset
    13
 * Redistributions in binary form must reproduce the above copyright notice, 
hgs
parents:
diff changeset
    14
   this list of conditions and the following disclaimer in the documentation 
hgs
parents:
diff changeset
    15
   and/or other materials provided with the distribution. 
hgs
parents:
diff changeset
    16
 * Neither the name of the <ORGANIZATION> nor the names of its contributors 
hgs
parents:
diff changeset
    17
   may be used to endorse or promote products derived from this software 
hgs
parents:
diff changeset
    18
   without specific prior written permission. 
hgs
parents:
diff changeset
    19
   
hgs
parents:
diff changeset
    20
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
hgs
parents:
diff changeset
    21
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
hgs
parents:
diff changeset
    22
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
hgs
parents:
diff changeset
    23
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
hgs
parents:
diff changeset
    24
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 
hgs
parents:
diff changeset
    25
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 
hgs
parents:
diff changeset
    26
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 
hgs
parents:
diff changeset
    27
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
hgs
parents:
diff changeset
    28
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
hgs
parents:
diff changeset
    29
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
hgs
parents:
diff changeset
    30
* ==============================================================================
hgs
parents:
diff changeset
    31
*/
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
#include <glib.h>
hgs
parents:
diff changeset
    34
#include <stdio.h>
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
#include "result_log.h"
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
void mrtLogHandler(const gchar* log_domain, GLogLevelFlags log_level,
hgs
parents:
diff changeset
    39
					const gchar* message, gpointer user_data)
hgs
parents:
diff changeset
    40
{
hgs
parents:
diff changeset
    41
	FILE *fp;
hgs
parents:
diff changeset
    42
	fp = fopen("c:\\logtests.txt","a");
hgs
parents:
diff changeset
    43
	
hgs
parents:
diff changeset
    44
	if(fp)
hgs
parents:
diff changeset
    45
	{
hgs
parents:
diff changeset
    46
		fprintf(fp,message);
hgs
parents:
diff changeset
    47
		fprintf(fp,"\n");
hgs
parents:
diff changeset
    48
		fclose(fp);
hgs
parents:
diff changeset
    49
	}
hgs
parents:
diff changeset
    50
}
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
void mrtPrintHandler(const gchar *message)
hgs
parents:
diff changeset
    53
{
hgs
parents:
diff changeset
    54
	FILE *fp;
hgs
parents:
diff changeset
    55
	fp = fopen("c:\\logtests.txt","a");
hgs
parents:
diff changeset
    56
	
hgs
parents:
diff changeset
    57
	if(fp)
hgs
parents:
diff changeset
    58
	{
hgs
parents:
diff changeset
    59
		fprintf(fp,message);
hgs
parents:
diff changeset
    60
		fprintf(fp,"\n");
hgs
parents:
diff changeset
    61
		fclose(fp);
hgs
parents:
diff changeset
    62
	}
hgs
parents:
diff changeset
    63
}
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
#define UNICODE_VALID(Char)                   \
hgs
parents:
diff changeset
    68
    ((Char) < 0x110000 &&                     \
hgs
parents:
diff changeset
    69
     (((Char) & 0xFFFFF800) != 0xD800) &&     \
hgs
parents:
diff changeset
    70
     ((Char) < 0xFDD0 || (Char) > 0xFDEF) &&  \
hgs
parents:
diff changeset
    71
     ((Char) & 0xFFFE) != 0xFFFE)
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
struct {
hgs
parents:
diff changeset
    77
  const gchar *text;
hgs
parents:
diff changeset
    78
  gint max_len;
hgs
parents:
diff changeset
    79
  gint offset;
hgs
parents:
diff changeset
    80
  gboolean valid;
hgs
parents:
diff changeset
    81
} test[] = {  
hgs
parents:
diff changeset
    82
  /* some tests to check max_len handling */
hgs
parents:
diff changeset
    83
  /* length 1 */
hgs
parents:
diff changeset
    84
  { "abcde", -1, 5, TRUE },
hgs
parents:
diff changeset
    85
  { "abcde", 3, 3, TRUE },
hgs
parents:
diff changeset
    86
  { "abcde", 5, 5, TRUE },
hgs
parents:
diff changeset
    87
  { "abcde", 7, 5, FALSE },
hgs
parents:
diff changeset
    88
  /* length 2 */
hgs
parents:
diff changeset
    89
  { "\xc2\xa9\xc2\xa9\xc2\xa9", -1, 6, TRUE }, 
hgs
parents:
diff changeset
    90
  { "\xc2\xa9\xc2\xa9\xc2\xa9",  1, 0, FALSE }, 
hgs
parents:
diff changeset
    91
  { "\xc2\xa9\xc2\xa9\xc2\xa9",  2, 2, TRUE }, 
hgs
parents:
diff changeset
    92
  { "\xc2\xa9\xc2\xa9\xc2\xa9",  3, 2, FALSE }, 
hgs
parents:
diff changeset
    93
  { "\xc2\xa9\xc2\xa9\xc2\xa9",  4, 4, TRUE }, 
hgs
parents:
diff changeset
    94
  { "\xc2\xa9\xc2\xa9\xc2\xa9",  5, 4, FALSE }, 
hgs
parents:
diff changeset
    95
  { "\xc2\xa9\xc2\xa9\xc2\xa9",  6, 6, TRUE }, 
hgs
parents:
diff changeset
    96
  { "\xc2\xa9\xc2\xa9\xc2\xa9",  7, 6, FALSE }, 
hgs
parents:
diff changeset
    97
  /* length 3 */
hgs
parents:
diff changeset
    98
  { "\xe2\x89\xa0\xe2\x89\xa0", -1, 6, TRUE },
hgs
parents:
diff changeset
    99
  { "\xe2\x89\xa0\xe2\x89\xa0",  1, 0, FALSE },
hgs
parents:
diff changeset
   100
  { "\xe2\x89\xa0\xe2\x89\xa0",  2, 0, FALSE },
hgs
parents:
diff changeset
   101
  { "\xe2\x89\xa0\xe2\x89\xa0",  3, 3, TRUE },
hgs
parents:
diff changeset
   102
  { "\xe2\x89\xa0\xe2\x89\xa0",  4, 3, FALSE },
hgs
parents:
diff changeset
   103
  { "\xe2\x89\xa0\xe2\x89\xa0",  5, 3, FALSE },
hgs
parents:
diff changeset
   104
  { "\xe2\x89\xa0\xe2\x89\xa0",  6, 6, TRUE },
hgs
parents:
diff changeset
   105
  { "\xe2\x89\xa0\xe2\x89\xa0",  7, 6, FALSE },
hgs
parents:
diff changeset
   106
hgs
parents:
diff changeset
   107
  /* examples from http://www.cl.cam.ac.uk/~mgk25/ucs/examples/UTF-8-test.txt */
hgs
parents:
diff changeset
   108
  /* greek 'kosme' */
hgs
parents:
diff changeset
   109
  { "\xce\xba\xe1\xbd\xb9\xcf\x83\xce\xbc\xce\xb5", -1, 11, TRUE },
hgs
parents:
diff changeset
   110
  /* first sequence of each length */
hgs
parents:
diff changeset
   111
  { "\x00", -1, 0, TRUE },
hgs
parents:
diff changeset
   112
  { "\xc2\x80", -1, 2, TRUE },
hgs
parents:
diff changeset
   113
  { "\xe0\xa0\x80", -1, 3, TRUE },
hgs
parents:
diff changeset
   114
  { "\xf0\x90\x80\x80", -1, 4, TRUE },
hgs
parents:
diff changeset
   115
  { "\xf8\x88\x80\x80\x80", -1, 0, FALSE },
hgs
parents:
diff changeset
   116
  { "\xfc\x84\x80\x80\x80\x80", -1, 0, FALSE },
hgs
parents:
diff changeset
   117
  /* last sequence of each length */
hgs
parents:
diff changeset
   118
  { "\x7f", -1, 1, TRUE },
hgs
parents:
diff changeset
   119
  { "\xdf\xbf", -1, 2, TRUE },
hgs
parents:
diff changeset
   120
  { "\xef\xbf\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   121
  { "\xf7\xbf\xbf\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   122
  { "\xfb\xbf\xbf\xbf\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   123
  { "\xfd\xbf\xbf\xbf\xbf\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   124
  /* other boundary conditions */
hgs
parents:
diff changeset
   125
  { "\xed\x9f\xbf", -1, 3, TRUE },
hgs
parents:
diff changeset
   126
  { "\xee\x80\x80", -1, 3, TRUE },
hgs
parents:
diff changeset
   127
  { "\xef\xbf\xbd", -1, 3, TRUE },
hgs
parents:
diff changeset
   128
  { "\xf4\x8f\xbf\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   129
  { "\xf4\x90\x80\x80", -1, 0, FALSE },
hgs
parents:
diff changeset
   130
  /* malformed sequences */
hgs
parents:
diff changeset
   131
  /* continuation bytes */
hgs
parents:
diff changeset
   132
  { "\x80", -1, 0, FALSE },
hgs
parents:
diff changeset
   133
  { "\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   134
  { "\x80\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   135
  { "\x80\xbf\x80", -1, 0, FALSE },
hgs
parents:
diff changeset
   136
  { "\x80\xbf\x80\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   137
  { "\x80\xbf\x80\xbf\x80", -1, 0, FALSE },
hgs
parents:
diff changeset
   138
  { "\x80\xbf\x80\xbf\x80\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   139
  { "\x80\xbf\x80\xbf\x80\xbf\x80", -1, 0, FALSE },
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
  /* all possible continuation byte */
hgs
parents:
diff changeset
   142
  { "\x80", -1, 0, FALSE },
hgs
parents:
diff changeset
   143
  { "\x81", -1, 0, FALSE },
hgs
parents:
diff changeset
   144
  { "\x82", -1, 0, FALSE },
hgs
parents:
diff changeset
   145
  { "\x83", -1, 0, FALSE },
hgs
parents:
diff changeset
   146
  { "\x84", -1, 0, FALSE },
hgs
parents:
diff changeset
   147
  { "\x85", -1, 0, FALSE },
hgs
parents:
diff changeset
   148
  { "\x86", -1, 0, FALSE },
hgs
parents:
diff changeset
   149
  { "\x87", -1, 0, FALSE },
hgs
parents:
diff changeset
   150
  { "\x88", -1, 0, FALSE },
hgs
parents:
diff changeset
   151
  { "\x89", -1, 0, FALSE },
hgs
parents:
diff changeset
   152
  { "\x8a", -1, 0, FALSE },
hgs
parents:
diff changeset
   153
  { "\x8b", -1, 0, FALSE },
hgs
parents:
diff changeset
   154
  { "\x8c", -1, 0, FALSE },
hgs
parents:
diff changeset
   155
  { "\x8d", -1, 0, FALSE },
hgs
parents:
diff changeset
   156
  { "\x8e", -1, 0, FALSE },
hgs
parents:
diff changeset
   157
  { "\x8f", -1, 0, FALSE },
hgs
parents:
diff changeset
   158
  { "\x90", -1, 0, FALSE },
hgs
parents:
diff changeset
   159
  { "\x91", -1, 0, FALSE },
hgs
parents:
diff changeset
   160
  { "\x92", -1, 0, FALSE },
hgs
parents:
diff changeset
   161
  { "\x93", -1, 0, FALSE },
hgs
parents:
diff changeset
   162
  { "\x94", -1, 0, FALSE },
hgs
parents:
diff changeset
   163
  { "\x95", -1, 0, FALSE },
hgs
parents:
diff changeset
   164
  { "\x96", -1, 0, FALSE },
hgs
parents:
diff changeset
   165
  { "\x97", -1, 0, FALSE },
hgs
parents:
diff changeset
   166
  { "\x98", -1, 0, FALSE },
hgs
parents:
diff changeset
   167
  { "\x99", -1, 0, FALSE },
hgs
parents:
diff changeset
   168
  { "\x9a", -1, 0, FALSE },
hgs
parents:
diff changeset
   169
  { "\x9b", -1, 0, FALSE },
hgs
parents:
diff changeset
   170
  { "\x9c", -1, 0, FALSE },
hgs
parents:
diff changeset
   171
  { "\x9d", -1, 0, FALSE },
hgs
parents:
diff changeset
   172
  { "\x9e", -1, 0, FALSE },
hgs
parents:
diff changeset
   173
  { "\x9f", -1, 0, FALSE },
hgs
parents:
diff changeset
   174
  { "\xa0", -1, 0, FALSE },
hgs
parents:
diff changeset
   175
  { "\xa1", -1, 0, FALSE },
hgs
parents:
diff changeset
   176
  { "\xa2", -1, 0, FALSE },
hgs
parents:
diff changeset
   177
  { "\xa3", -1, 0, FALSE },
hgs
parents:
diff changeset
   178
  { "\xa4", -1, 0, FALSE },
hgs
parents:
diff changeset
   179
  { "\xa5", -1, 0, FALSE },
hgs
parents:
diff changeset
   180
  { "\xa6", -1, 0, FALSE },
hgs
parents:
diff changeset
   181
  { "\xa7", -1, 0, FALSE },
hgs
parents:
diff changeset
   182
  { "\xa8", -1, 0, FALSE },
hgs
parents:
diff changeset
   183
  { "\xa9", -1, 0, FALSE },
hgs
parents:
diff changeset
   184
  { "\xaa", -1, 0, FALSE },
hgs
parents:
diff changeset
   185
  { "\xab", -1, 0, FALSE },
hgs
parents:
diff changeset
   186
  { "\xac", -1, 0, FALSE },
hgs
parents:
diff changeset
   187
  { "\xad", -1, 0, FALSE },
hgs
parents:
diff changeset
   188
  { "\xae", -1, 0, FALSE },
hgs
parents:
diff changeset
   189
  { "\xaf", -1, 0, FALSE },
hgs
parents:
diff changeset
   190
  { "\xb0", -1, 0, FALSE },
hgs
parents:
diff changeset
   191
  { "\xb1", -1, 0, FALSE },
hgs
parents:
diff changeset
   192
  { "\xb2", -1, 0, FALSE },
hgs
parents:
diff changeset
   193
  { "\xb3", -1, 0, FALSE },
hgs
parents:
diff changeset
   194
  { "\xb4", -1, 0, FALSE },
hgs
parents:
diff changeset
   195
  { "\xb5", -1, 0, FALSE },
hgs
parents:
diff changeset
   196
  { "\xb6", -1, 0, FALSE },
hgs
parents:
diff changeset
   197
  { "\xb7", -1, 0, FALSE },
hgs
parents:
diff changeset
   198
  { "\xb8", -1, 0, FALSE },
hgs
parents:
diff changeset
   199
  { "\xb9", -1, 0, FALSE },
hgs
parents:
diff changeset
   200
  { "\xba", -1, 0, FALSE },
hgs
parents:
diff changeset
   201
  { "\xbb", -1, 0, FALSE },
hgs
parents:
diff changeset
   202
  { "\xbc", -1, 0, FALSE },
hgs
parents:
diff changeset
   203
  { "\xbd", -1, 0, FALSE },
hgs
parents:
diff changeset
   204
  { "\xbe", -1, 0, FALSE },
hgs
parents:
diff changeset
   205
  { "\xbf", -1, 0, FALSE },
hgs
parents:
diff changeset
   206
  /* lone start characters */
hgs
parents:
diff changeset
   207
  { "\xc0\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   208
  { "\xc1\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   209
  { "\xc2\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   210
  { "\xc3\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   211
  { "\xc4\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   212
  { "\xc5\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   213
  { "\xc6\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   214
  { "\xc7\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   215
  { "\xc8\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   216
  { "\xc9\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   217
  { "\xca\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   218
  { "\xcb\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   219
  { "\xcc\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   220
  { "\xcd\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   221
  { "\xce\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   222
  { "\xcf\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   223
  { "\xd0\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   224
  { "\xd1\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   225
  { "\xd2\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   226
  { "\xd3\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   227
  { "\xd4\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   228
  { "\xd5\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   229
  { "\xd6\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   230
  { "\xd7\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   231
  { "\xd8\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   232
  { "\xd9\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   233
  { "\xda\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   234
  { "\xdb\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   235
  { "\xdc\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   236
  { "\xdd\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   237
  { "\xde\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   238
  { "\xdf\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   239
  { "\xe0\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   240
  { "\xe1\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   241
  { "\xe2\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   242
  { "\xe3\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   243
  { "\xe4\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   244
  { "\xe5\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   245
  { "\xe6\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   246
  { "\xe7\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   247
  { "\xe8\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   248
  { "\xe9\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   249
  { "\xea\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   250
  { "\xeb\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   251
  { "\xec\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   252
  { "\xed\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   253
  { "\xee\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   254
  { "\xef\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   255
  { "\xf0\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   256
  { "\xf1\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   257
  { "\xf2\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   258
  { "\xf3\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   259
  { "\xf4\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   260
  { "\xf5\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   261
  { "\xf6\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   262
  { "\xf7\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   263
  { "\xf8\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   264
  { "\xf9\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   265
  { "\xfa\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   266
  { "\xfb\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   267
  { "\xfc\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   268
  { "\xfd\x20", -1, 0, FALSE },
hgs
parents:
diff changeset
   269
  /* missing continuation bytes */
hgs
parents:
diff changeset
   270
  { "\x20\xc0", -1, 1, FALSE },
hgs
parents:
diff changeset
   271
  { "\x20\xe0\x80", -1, 1, FALSE },
hgs
parents:
diff changeset
   272
  { "\x20\xf0\x80\x80", -1, 1, FALSE },
hgs
parents:
diff changeset
   273
  { "\x20\xf8\x80\x80\x80", -1, 1, FALSE },
hgs
parents:
diff changeset
   274
  { "\x20\xfc\x80\x80\x80\x80", -1, 1, FALSE },
hgs
parents:
diff changeset
   275
  { "\x20\xdf", -1, 1, FALSE },
hgs
parents:
diff changeset
   276
  { "\x20\xef\xbf", -1, 1, FALSE },
hgs
parents:
diff changeset
   277
  { "\x20\xf7\xbf\xbf", -1, 1, FALSE },
hgs
parents:
diff changeset
   278
  { "\x20\xfb\xbf\xbf\xbf", -1, 1, FALSE },
hgs
parents:
diff changeset
   279
  { "\x20\xfd\xbf\xbf\xbf\xbf", -1, 1, FALSE },
hgs
parents:
diff changeset
   280
  /* impossible bytes */
hgs
parents:
diff changeset
   281
  { "\x20\xfe\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   282
  { "\x20\xff\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   283
  /* overlong sequences */
hgs
parents:
diff changeset
   284
  { "\x20\xc0\xaf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   285
  { "\x20\xe0\x80\xaf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   286
  { "\x20\xf0\x80\x80\xaf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   287
  { "\x20\xf8\x80\x80\x80\xaf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   288
  { "\x20\xfc\x80\x80\x80\x80\xaf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   289
  { "\x20\xc1\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   290
  { "\x20\xe0\x9f\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   291
  { "\x20\xf0\x8f\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   292
  { "\x20\xf8\x87\xbf\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   293
  { "\x20\xfc\x83\xbf\xbf\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   294
  { "\x20\xc0\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   295
  { "\x20\xe0\x80\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   296
  { "\x20\xf0\x80\x80\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   297
  { "\x20\xf8\x80\x80\x80\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   298
  { "\x20\xfc\x80\x80\x80\x80\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   299
  /* illegal code positions */
hgs
parents:
diff changeset
   300
  { "\x20\xed\xa0\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   301
  { "\x20\xed\xad\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   302
  { "\x20\xed\xae\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   303
  { "\x20\xed\xaf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   304
  { "\x20\xed\xb0\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   305
  { "\x20\xed\xbe\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   306
  { "\x20\xed\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   307
  { "\x20\xed\xa0\x80\xed\xb0\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   308
  { "\x20\xed\xa0\x80\xed\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   309
  { "\x20\xed\xad\xbf\xed\xb0\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   310
  { "\x20\xed\xad\xbf\xed\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   311
  { "\x20\xed\xae\x80\xed\xb0\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   312
  { "\x20\xed\xae\x80\xed\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   313
  { "\x20\xed\xaf\xbf\xed\xb0\x80\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   314
  { "\x20\xed\xaf\xbf\xed\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   315
  { "\x20\xef\xbf\xbe\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   316
  { "\x20\xef\xbf\xbf\x20", -1, 1, FALSE },
hgs
parents:
diff changeset
   317
hgs
parents:
diff changeset
   318
  { NULL, }
hgs
parents:
diff changeset
   319
};
hgs
parents:
diff changeset
   320
hgs
parents:
diff changeset
   321
extern int do_test (gint         index, const gchar *text,  gint         max_len,	 gint         offset, gboolean     valid);
hgs
parents:
diff changeset
   322
hgs
parents:
diff changeset
   323
int
hgs
parents:
diff changeset
   324
main (int argc, char *argv[])
hgs
parents:
diff changeset
   325
{
hgs
parents:
diff changeset
   326
  gint i;
hgs
parents:
diff changeset
   327
 	  
hgs
parents:
diff changeset
   328
  int any_failed = 0;
hgs
parents:
diff changeset
   329
  int ret;
hgs
parents:
diff changeset
   330
  for (i = 0; test[i].text; i++)
hgs
parents:
diff changeset
   331
  {
hgs
parents:
diff changeset
   332
  	ret = do_test (i, test[i].text, test[i].max_len, 
hgs
parents:
diff changeset
   333
	     test[i].offset, test[i].valid);
hgs
parents:
diff changeset
   334
	 any_failed += ret;
hgs
parents:
diff changeset
   335
  
hgs
parents:
diff changeset
   336
  }
hgs
parents:
diff changeset
   337
    
hgs
parents:
diff changeset
   338
hgs
parents:
diff changeset
   339
  #ifdef SYMBIAN
hgs
parents:
diff changeset
   340
  testResultXml("gcce-load",any_failed);
hgs
parents:
diff changeset
   341
  #endif /* EMULATOR */
hgs
parents:
diff changeset
   342
  
hgs
parents:
diff changeset
   343
  return any_failed ? 1 : 0;
hgs
parents:
diff changeset
   344
}