[funini.com] -> [kei@sodan] -> Kernel Reading

root/fs/jfs/jfs_unicode.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


DEFINITIONS

This source file includes following definitions.
  1. UniStrcpy
  2. UniStrncpy_le
  3. UniStrncmp_le
  4. UniStrncpy_to_le
  5. UniStrncpy_from_le
  6. UniToupper
  7. UniStrupr

/*
 *   Copyright (C) International Business Machines Corp., 2000-2002
 *   Portions Copyright (C) Christoph Hellwig, 2001-2002
 *
 *   This program is free software;  you can redistribute it and/or modify
 *   it under the terms of the GNU General Public License as published by
 *   the Free Software Foundation; either version 2 of the License, or
 *   (at your option) any later version.
 *
 *   This program is distributed in the hope that it will be useful,
 *   but WITHOUT ANY WARRANTY;  without even the implied warranty of
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
 *   the GNU General Public License for more details.
 *
 *   You should have received a copy of the GNU General Public License
 *   along with this program;  if not, write to the Free Software
 *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 */
#ifndef _H_JFS_UNICODE
#define _H_JFS_UNICODE

#include <asm/byteorder.h>
#include "jfs_types.h"

typedef struct {
        wchar_t start;
        wchar_t end;
        signed char *table;
} UNICASERANGE;

extern signed char UniUpperTable[512];
extern UNICASERANGE UniUpperRange[];
extern int get_UCSname(struct component_name *, struct dentry *);
extern int jfs_strfromUCS_le(char *, const __le16 *, int, struct nls_table *);

#define free_UCSname(COMP) kfree((COMP)->name)

/*
 * UniStrcpy:  Copy a string
 */
static inline wchar_t *UniStrcpy(wchar_t * ucs1, const wchar_t * ucs2)
{
        wchar_t *anchor = ucs1; /* save the start of result string */

        while ((*ucs1++ = *ucs2++));
        return anchor;
}



/*
 * UniStrncpy:  Copy length limited string with pad
 */
static inline __le16 *UniStrncpy_le(__le16 * ucs1, const __le16 * ucs2,
                                  size_t n)
{
        __le16 *anchor = ucs1;

        while (n-- && *ucs2)    /* Copy the strings */
                *ucs1++ = *ucs2++;

        n++;
        while (n--)             /* Pad with nulls */
                *ucs1++ = 0;
        return anchor;
}

/*
 * UniStrncmp_le:  Compare length limited string - native to little-endian
 */
static inline int UniStrncmp_le(const wchar_t * ucs1, const __le16 * ucs2,
                                size_t n)
{
        if (!n)
                return 0;       /* Null strings are equal */
        while ((*ucs1 == __le16_to_cpu(*ucs2)) && *ucs1 && --n) {
                ucs1++;
                ucs2++;
        }
        return (int) *ucs1 - (int) __le16_to_cpu(*ucs2);
}

/*
 * UniStrncpy_to_le:  Copy length limited string with pad to little-endian
 */
static inline __le16 *UniStrncpy_to_le(__le16 * ucs1, const wchar_t * ucs2,
                                       size_t n)
{
        __le16 *anchor = ucs1;

        while (n-- && *ucs2)    /* Copy the strings */
                *ucs1++ = cpu_to_le16(*ucs2++);

        n++;
        while (n--)             /* Pad with nulls */
                *ucs1++ = 0;
        return anchor;
}

/*
 * UniStrncpy_from_le:  Copy length limited string with pad from little-endian
 */
static inline wchar_t *UniStrncpy_from_le(wchar_t * ucs1, const __le16 * ucs2,
                                          size_t n)
{
        wchar_t *anchor = ucs1;

        while (n-- && *ucs2)    /* Copy the strings */
                *ucs1++ = __le16_to_cpu(*ucs2++);

        n++;
        while (n--)             /* Pad with nulls */
                *ucs1++ = 0;
        return anchor;
}

/*
 * UniToupper:  Convert a unicode character to upper case
 */
static inline wchar_t UniToupper(wchar_t uc)
{
        UNICASERANGE *rp;

        if (uc < sizeof(UniUpperTable)) {       /* Latin characters */
                return uc + UniUpperTable[uc];  /* Use base tables */
        } else {
                rp = UniUpperRange;     /* Use range tables */
                while (rp->start) {
                        if (uc < rp->start)     /* Before start of range */
                                return uc;      /* Uppercase = input */
                        if (uc <= rp->end)      /* In range */
                                return uc + rp->table[uc - rp->start];
                        rp++;   /* Try next range */
                }
        }
        return uc;              /* Past last range */
}


/*
 * UniStrupr:  Upper case a unicode string
 */
static inline wchar_t *UniStrupr(wchar_t * upin)
{
        wchar_t *up;

        up = upin;
        while (*up) {           /* For all characters */
                *up = UniToupper(*up);
                up++;
        }
        return upin;            /* Return input pointer */
}

#endif                          /* !_H_JFS_UNICODE */

/* [<][>][^][v][top][bottom][index][help] */

[funini.com] -> [kei@sodan] -> Kernel Reading