2006-08-12 16:56:45 -04:00
|
|
|
! Copyright (C) 2003, 2006 Slava Pestov.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2005-05-05 16:51:38 -04:00
|
|
|
IN: strings
|
2006-05-15 01:01:47 -04:00
|
|
|
USING: generic kernel kernel-internals math sequences
|
2005-09-10 18:27:31 -04:00
|
|
|
sequences-internals ;
|
2004-07-16 02:26:21 -04:00
|
|
|
|
2006-08-15 03:01:24 -04:00
|
|
|
M: string equal?
|
2006-05-18 22:20:23 -04:00
|
|
|
over string? [
|
|
|
|
over hashcode over hashcode number=
|
|
|
|
[ sequence= ] [ 2drop f ] if
|
|
|
|
] [
|
|
|
|
2drop f
|
|
|
|
] if ;
|
|
|
|
|
2006-01-02 00:51:03 -05:00
|
|
|
M: string hashcode
|
2005-12-25 21:05:31 -05:00
|
|
|
dup string-hashcode [ ] [
|
|
|
|
dup rehash-string string-hashcode
|
|
|
|
] ?if ;
|
|
|
|
|
2006-07-28 03:54:46 -04:00
|
|
|
M: string nth bounds-check nth-unsafe ;
|
2005-04-02 02:39:33 -05:00
|
|
|
|
2006-01-02 00:51:03 -05:00
|
|
|
M: string nth-unsafe >r >fixnum r> char-slot ;
|
2005-09-10 18:27:31 -04:00
|
|
|
|
2006-01-02 00:51:03 -05:00
|
|
|
M: string set-nth bounds-check set-nth-unsafe ;
|
2005-12-25 21:05:31 -05:00
|
|
|
|
2006-01-02 00:51:03 -05:00
|
|
|
M: string set-nth-unsafe
|
2005-12-25 21:05:31 -05:00
|
|
|
f over set-string-hashcode
|
|
|
|
>r >fixnum >r >fixnum r> r> set-char-slot ;
|
2005-05-05 16:51:38 -04:00
|
|
|
|
2006-01-02 00:51:03 -05:00
|
|
|
M: string clone (clone) ;
|
2005-05-05 16:51:38 -04:00
|
|
|
|
2006-05-18 22:20:23 -04:00
|
|
|
M: string resize resize-string ;
|
|
|
|
|
2005-04-29 02:37:12 -04:00
|
|
|
! Characters
|
2006-08-16 21:55:53 -04:00
|
|
|
PREDICATE: integer blank " \t\n\r" member? ;
|
|
|
|
PREDICATE: integer letter CHAR: a CHAR: z between? ;
|
|
|
|
PREDICATE: integer LETTER CHAR: A CHAR: Z between? ;
|
|
|
|
PREDICATE: integer digit CHAR: 0 CHAR: 9 between? ;
|
2004-12-18 23:18:32 -05:00
|
|
|
PREDICATE: integer printable CHAR: \s CHAR: ~ between? ;
|
2006-08-16 21:55:53 -04:00
|
|
|
PREDICATE: integer control "\0\e\r\n\t\u0008\u007f" member? ;
|
|
|
|
PREDICATE: printable quotable "\"\\" member? not ;
|
2004-08-08 17:20:54 -04:00
|
|
|
|
2006-08-12 16:56:45 -04:00
|
|
|
UNION: Letter letter LETTER ;
|
|
|
|
UNION: alpha Letter digit ;
|
|
|
|
|
2006-08-16 21:55:53 -04:00
|
|
|
: ch>lower ( ch -- lower ) dup LETTER? [ HEX: 20 + ] when ;
|
|
|
|
: ch>upper ( ch -- lower ) dup letter? [ HEX: 20 - ] when ;
|
|
|
|
: >lower ( str -- lower ) [ ch>lower ] map ;
|
|
|
|
: >upper ( str -- upper ) [ ch>upper ] map ;
|
2005-10-16 21:50:43 -04:00
|
|
|
|
2006-06-05 23:26:44 -04:00
|
|
|
: ch>string ( ch -- str ) 1 swap <string> ;
|
2006-01-02 00:51:03 -05:00
|
|
|
|
2006-08-16 21:55:53 -04:00
|
|
|
: >string ( seq -- str )
|
2006-07-24 00:20:08 -04:00
|
|
|
[ string? ] [ 0 <string> ] >sequence ; inline
|
2006-01-02 00:51:03 -05:00
|
|
|
|
|
|
|
M: string thaw drop SBUF" " clone ;
|
|
|
|
|
2006-08-16 21:55:53 -04:00
|
|
|
M: string like drop dup string? [ >string ] unless ;
|