/*1* Copyright (c) 2004 Kungliga Tekniska Högskolan2* (Royal Institute of Technology, Stockholm, Sweden).3* All rights reserved.4*5* Redistribution and use in source and binary forms, with or without6* modification, are permitted provided that the following conditions7* are met:8*9* 1. Redistributions of source code must retain the above copyright10* notice, this list of conditions and the following disclaimer.11*12* 2. Redistributions in binary form must reproduce the above copyright13* notice, this list of conditions and the following disclaimer in the14* documentation and/or other materials provided with the distribution.15*16* 3. Neither the name of the Institute nor the names of its contributors17* may be used to endorse or promote products derived from this software18* without specific prior written permission.19*20* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND21* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE22* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE23* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE24* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL25* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS26* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)27* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT28* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY29* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF30* SUCH DAMAGE.31*/3233#include "windlocl.h"3435#include <stdlib.h>3637#include "bidi_table.h"3839static int40range_entry_cmp(const void *a, const void *b)41{42const struct range_entry *ea = (const struct range_entry*)a;43const struct range_entry *eb = (const struct range_entry*)b;4445if (ea->start >= eb->start && ea->start < eb->start + eb->len)46return 0;47return ea->start - eb->start;48}4950static int51is_ral(uint32_t cp)52{53struct range_entry ee = {cp};54void *s = bsearch(&ee, _wind_ral_table, _wind_ral_table_size,55sizeof(_wind_ral_table[0]),56range_entry_cmp);57return s != NULL;58}5960static int61is_l(uint32_t cp)62{63struct range_entry ee = {cp};64void *s = bsearch(&ee, _wind_l_table, _wind_l_table_size,65sizeof(_wind_l_table[0]),66range_entry_cmp);67return s != NULL;68}6970int71_wind_stringprep_testbidi(const uint32_t *in, size_t in_len, wind_profile_flags flags)72{73size_t i;74unsigned ral = 0;75unsigned l = 0;7677if ((flags & (WIND_PROFILE_NAME|WIND_PROFILE_SASL)) == 0)78return 0;7980for (i = 0; i < in_len; ++i) {81ral |= is_ral(in[i]);82l |= is_l(in[i]);83}84if (ral) {85if (l)86return 1;87if (!is_ral(in[0]) || !is_ral(in[in_len - 1]))88return 1;89}90return 0;91}929394