*** empty log message ***

This commit is contained in:
hyung-hwan 2007-01-19 03:23:47 +00:00
parent 277e6d593f
commit 3208b3b2ff
3 changed files with 82 additions and 54 deletions

View File

@ -1,5 +1,5 @@
/* /*
* $Id: Awk.java,v 1.17 2007-01-18 14:34:17 bacon Exp $ * $Id: Awk.java,v 1.18 2007-01-19 03:23:47 bacon Exp $
*/ */
package ase.awk; package ase.awk;
@ -20,12 +20,17 @@ public abstract class Awk
System.getProperty("os.name")); os.arch / os.version; System.getProperty("os.name")); os.arch / os.version;
*/ */
//System.load ("c://projects//ase/awk/aseawk.dll"); //System.load ("c://projects//ase/awk/aseawk.dll");
URL url = ase.awk.Awk.class.getResource("aseawk.dll");
if (url == null) url = ase.awk.Awk.class.getResource("libaseawk_jni.so");
if (url != null) System.load (url.getFile());
/*
AccessController.doPrivileged (new PrivilegedAction () AccessController.doPrivileged (new PrivilegedAction ()
{ {
public Object run () public Object run ()
{ {
URL url = ase.awk.Awk.class.getResource("aseawk.dll"); URL url = ase.awk.Awk.class.getResource("aseawk.dll");
if (url == null) url = ase.awk.Awk.class.getResource("libaseawk.so"); if (url == null) url = ase.awk.Awk.class.getResource("libaseawk_jni.so");
if (url != null) System.load (url.getFile()); if (url != null) System.load (url.getFile());
//System.load ("c://projects//ase/awk/aseawk.dll"); //System.load ("c://projects//ase/awk/aseawk.dll");
@ -33,6 +38,7 @@ public abstract class Awk
return null; return null;
} }
}); });
*/
} }
private long handle; private long handle;

View File

@ -1,5 +1,5 @@
/* /*
* $Id: jni.c,v 1.48 2007-01-07 07:30:40 bacon Exp $ * $Id: jni.c,v 1.49 2007-01-19 03:23:47 bacon Exp $
*/ */
#include <stdio.h> #include <stdio.h>
@ -13,6 +13,8 @@
#include <ase/awk/jni.h> #include <ase/awk/jni.h>
#include <ase/awk/awk_i.h> #include <ase/awk/awk_i.h>
#include "../etc/printf.c"
#ifdef _WIN32 #ifdef _WIN32
#include <windows.h> #include <windows.h>
#include <tchar.h> #include <tchar.h>
@ -125,7 +127,7 @@ static int __awk_sprintf (
/* TODO: check buffer overflow */ /* TODO: check buffer overflow */
n = vsprintf (buf, fmt, ap); n = vsprintf (buf, fmt, ap);
#else #else
n = xp_vsprintf (buf, len, fmt, ap); n = ase_vsprintf (buf, len, fmt, ap);
#endif #endif
va_end (ap); va_end (ap);
return n; return n;
@ -154,7 +156,7 @@ static void __awk_aprintf (const ase_char_t* fmt, ...)
#elif defined(__MSDOS__) #elif defined(__MSDOS__)
vprintf (fmt, ap); vprintf (fmt, ap);
#else #else
xp_vprintf (fmt, ap); ase_vprintf (fmt, ap);
#endif #endif
va_end (ap); va_end (ap);
} }
@ -169,7 +171,7 @@ static void __awk_dprintf (const ase_char_t* fmt, ...)
#elif defined(__MSDOS__) #elif defined(__MSDOS__)
vfprintf (stderr, fmt, ap); vfprintf (stderr, fmt, ap);
#else #else
xp_vfprintf (stderr, fmt, ap); ase_vfprintf (stderr, fmt, ap);
#endif #endif
va_end (ap); va_end (ap);

View File

@ -1,45 +1,46 @@
/* /*
* $Id: printf.c,v 1.1 2006-12-24 16:07:13 bacon Exp $ * $Id: printf.c,v 1.2 2007-01-19 03:23:47 bacon Exp $
*/ */
#include <stdarg.h> #include <stdarg.h>
#include <stdio.h> #include <stdio.h>
#include <wchar.h> #include <wchar.h>
#include <stdlib.h>
static ase_char_t* __adjust_format (const ase_char_t* format); static ase_char_t* __adjust_format (const ase_char_t* format);
int xp_vprintf (const ase_char_t* fmt, va_list ap); int ase_vprintf (const ase_char_t* fmt, va_list ap);
int xp_vfprintf (FILE *stream, const ase_char_t* fmt, va_list ap); int ase_vfprintf (FILE *stream, const ase_char_t* fmt, va_list ap);
int xp_vsprintf (ase_char_t* buf, size_t size, const ase_char_t* fmt, va_list ap); int ase_vsprintf (ase_char_t* buf, size_t size, const ase_char_t* fmt, va_list ap);
int xp_printf (const ase_char_t* fmt, ...) int ase_printf (const ase_char_t* fmt, ...)
{ {
int n; int n;
va_list ap; va_list ap;
va_start (ap, fmt); va_start (ap, fmt);
n = xp_vprintf (fmt, ap); n = ase_vprintf (fmt, ap);
va_end (ap); va_end (ap);
return n; return n;
} }
int xp_fprintf (FILE* file, const ase_char_t* fmt, ...) int ase_fprintf (FILE* file, const ase_char_t* fmt, ...)
{ {
int n; int n;
va_list ap; va_list ap;
va_start (ap, fmt); va_start (ap, fmt);
n = xp_vfprintf (file, fmt, ap); n = ase_vfprintf (file, fmt, ap);
va_end (ap); va_end (ap);
return n; return n;
} }
int xp_vprintf (const ase_char_t* fmt, va_list ap) int ase_vprintf (const ase_char_t* fmt, va_list ap)
{ {
return xp_vfprintf (stdout, fmt, ap); return ase_vfprintf (stdout, fmt, ap);
} }
int xp_vfprintf (FILE *stream, const ase_char_t* fmt, va_list ap) int ase_vfprintf (FILE *stream, const ase_char_t* fmt, va_list ap)
{ {
int n; int n;
ase_char_t* nf = __adjust_format (fmt); ase_char_t* nf = __adjust_format (fmt);
@ -54,18 +55,18 @@ int xp_vfprintf (FILE *stream, const ase_char_t* fmt, va_list ap)
return n; return n;
} }
int xp_sprintf (ase_char_t* buf, size_t size, const ase_char_t* fmt, ...) int ase_sprintf (ase_char_t* buf, size_t size, const ase_char_t* fmt, ...)
{ {
int n; int n;
va_list ap; va_list ap;
va_start (ap, fmt); va_start (ap, fmt);
n = xp_vsprintf (buf, size, fmt, ap); n = ase_vsprintf (buf, size, fmt, ap);
va_end (ap); va_end (ap);
return n; return n;
} }
int xp_vsprintf (ase_char_t* buf, size_t size, const ase_char_t* fmt, va_list ap) int ase_vsprintf (ase_char_t* buf, size_t size, const ase_char_t* fmt, va_list ap)
{ {
int n; int n;
ase_char_t* nf = __adjust_format (fmt); ase_char_t* nf = __adjust_format (fmt);
@ -92,35 +93,53 @@ int xp_vsprintf (ase_char_t* buf, size_t size, const ase_char_t* fmt, va_list ap
#define MOD_LONG 2 #define MOD_LONG 2
#define MOD_LONGLONG 3 #define MOD_LONGLONG 3
#define ADDC(str,c) \ #define ADDC(buf,c) \
do { \ do { \
if (xp_str_ccat(&str, c) == (size_t)-1) { \ if (buf.len >= buf.cap) \
xp_str_close (&str); \ { \
return NULL; \ ase_char_t* tmp; \
tmp = (ase_char_t*)realloc ( \
buf.ptr, sizeof(ase_char_t)*(buf.cap+256+1)); \
if (tmp == NULL) \
{ \
free (buf.ptr); \
return NULL; \
} \
buf.ptr = tmp; \
buf.cap = buf.cap + 256; \
} \ } \
buf.ptr[buf.len++] = c; \
} while (0) } while (0)
static ase_char_t* __adjust_format (const ase_char_t* format) static ase_char_t* __adjust_format (const ase_char_t* format)
{ {
const ase_char_t* fp = format; const ase_char_t* fp = format;
int modifier; int modifier;
xp_str_t str;
ase_char_t ch; ase_char_t ch;
if (xp_str_open (&str, 256) == NULL) return NULL; struct
{
ase_char_t* ptr;
ase_size_t len;
ase_size_t cap;
} buf;
buf.len = 0;
buf.cap = 256;
buf.ptr = (ase_char_t*) malloc (sizeof(ase_char_t)*(buf.cap+1));
if (buf.ptr == NULL) return NULL;
while (*fp != ASE_T('\0')) while (*fp != ASE_T('\0'))
{ {
while (*fp != ASE_T('\0') && *fp != ASE_T('%')) while (*fp != ASE_T('\0') && *fp != ASE_T('%'))
{ {
ADDC (str, *fp++); ADDC (buf, *fp++);
} }
if (*fp == ASE_T('\0')) break; if (*fp == ASE_T('\0')) break;
xp_assert (*fp == ASE_T('%'));
ch = *fp++; ch = *fp++;
ADDC (str, ch); /* add % */ ADDC (buf, ch); /* add % */
ch = *fp++; ch = *fp++;
@ -130,14 +149,14 @@ static ase_char_t* __adjust_format (const ase_char_t* format)
if (ch == ASE_T(' ') || ch == ASE_T('+') || if (ch == ASE_T(' ') || ch == ASE_T('+') ||
ch == ASE_T('-') || ch == ASE_T('#')) ch == ASE_T('-') || ch == ASE_T('#'))
{ {
ADDC (str, ch); ADDC (buf, ch);
ch = *fp++; ch = *fp++;
} }
else else
{ {
if (ch == ASE_T('0')) if (ch == ASE_T('0'))
{ {
ADDC (str, ch); ADDC (buf, ch);
ch = *fp++; ch = *fp++;
} }
@ -148,14 +167,14 @@ static ase_char_t* __adjust_format (const ase_char_t* format)
/* check the width */ /* check the width */
if (ch == ASE_T('*')) if (ch == ASE_T('*'))
{ {
ADDC (str, ch); ADDC (buf, ch);
ch = *fp++; ch = *fp++;
} }
else else
{ {
while (xp_isdigit(ch)) while (ase_isdigit(ch))
{ {
ADDC (str, ch); ADDC (buf, ch);
ch = *fp++; ch = *fp++;
} }
} }
@ -163,19 +182,19 @@ static ase_char_t* __adjust_format (const ase_char_t* format)
/* precision */ /* precision */
if (ch == ASE_T('.')) if (ch == ASE_T('.'))
{ {
ADDC (str, ch); ADDC (buf, ch);
ch = *fp++; ch = *fp++;
if (ch == ASE_T('*')) if (ch == ASE_T('*'))
{ {
ADDC (str, ch); ADDC (buf, ch);
ch = *fp++; ch = *fp++;
} }
else else
{ {
while (xp_isdigit(ch)) while (ase_isdigit(ch))
{ {
ADDC (str, ch); ADDC (buf, ch);
ch = *fp++; ch = *fp++;
} }
} }
@ -195,23 +214,23 @@ static ase_char_t* __adjust_format (const ase_char_t* format)
/* type */ /* type */
if (ch == ASE_T('%')) ADDC (str, ch); if (ch == ASE_T('%')) ADDC (buf, ch);
else if (ch == ASE_T('c') || ch == ASE_T('s')) else if (ch == ASE_T('c') || ch == ASE_T('s'))
{ {
#if !defined(ASE_CHAR_IS_MCHAR) && !defined(_WIN32) #if !defined(ASE_CHAR_IS_MCHAR) && !defined(_WIN32)
ADDC (str, 'l'); ADDC (buf, 'l');
#endif #endif
ADDC (str, ch); ADDC (buf, ch);
} }
else if (ch == ASE_T('C') || ch == ASE_T('S')) else if (ch == ASE_T('C') || ch == ASE_T('S'))
{ {
#ifdef _WIN32 #ifdef _WIN32
ADDC (str, ch); ADDC (buf, ch);
#else #else
#ifdef ASE_CHAR_IS_MCHAR #ifdef ASE_CHAR_IS_MCHAR
ADDC (str, 'l'); ADDC (buf, 'l');
#endif #endif
ADDC (str, xp_tolower(ch)); ADDC (buf, ase_tolower(ch));
#endif #endif
} }
else if (ch == ASE_T('d') || ch == ASE_T('i') || else if (ch == ASE_T('d') || ch == ASE_T('i') ||
@ -220,29 +239,30 @@ static ase_char_t* __adjust_format (const ase_char_t* format)
{ {
if (modifier == MOD_SHORT) if (modifier == MOD_SHORT)
{ {
ADDC (str, 'h'); ADDC (buf, 'h');
} }
else if (modifier == MOD_LONG) else if (modifier == MOD_LONG)
{ {
ADDC (str, 'l'); ADDC (buf, 'l');
} }
else if (modifier == MOD_LONGLONG) else if (modifier == MOD_LONGLONG)
{ {
#if defined(_WIN32) && !defined(__LCC__) #if defined(_WIN32) && !defined(__LCC__)
ADDC (str, 'I'); ADDC (buf, 'I');
ADDC (str, '6'); ADDC (buf, '6');
ADDC (str, '4'); ADDC (buf, '4');
#else #else
ADDC (str, 'l'); ADDC (buf, 'l');
ADDC (str, 'l'); ADDC (buf, 'l');
#endif #endif
} }
ADDC (str, ch); ADDC (buf, ch);
} }
else if (ch == ASE_T('\0')) break; else if (ch == ASE_T('\0')) break;
else ADDC (str, ch); else ADDC (buf, ch);
} }
return xp_str_cield (&str); buf.ptr[buf.len] = ASE_T('\0');
return buf.ptr;
} }