factor/library/collections/strings.factor

52 lines
1.6 KiB
Factor
Raw Normal View History

! Copyright (C) 2003, 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
2005-05-05 16:51:38 -04:00
IN: strings
USING: generic kernel kernel-internals lists math sequences
sequences-internals ;
2004-07-16 02:26:21 -04:00
M: string hashcode ( string -- n )
#! Recompute cached hashcode if necessary.
dup string-hashcode [ ] [
dup rehash-string string-hashcode
] ?if ;
M: string nth ( n str -- ch ) bounds-check char-slot ;
2005-04-02 02:39:33 -05:00
2005-09-24 16:34:10 -04:00
M: string nth-unsafe ( n str -- ch ) >r >fixnum r> char-slot ;
M: string set-nth ( ch n str -- )
bounds-check set-nth-unsafe ;
M: string set-nth-unsafe ( ch n str -- )
#! Reset cached hashcode.
f over set-string-hashcode
>r >fixnum >r >fixnum r> r> set-char-slot ;
2005-05-05 16:51:38 -04:00
M: string clone ( string -- string ) (clone) ;
2005-05-05 16:51:38 -04:00
! Characters
2005-07-16 22:16:18 -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? ;
PREDICATE: integer printable CHAR: \s CHAR: ~ between? ;
2005-10-07 20:26:21 -04:00
PREDICATE: integer control "\0\e\r\n\t\u0008\u007f" member? ;
: ch>lower ( n -- n ) dup LETTER? [ HEX: 20 + ] when ;
: ch>upper ( n -- n ) dup letter? [ HEX: 20 - ] when ;
: >lower ( str -- str ) [ ch>lower ] map ;
: >upper ( str -- str ) [ ch>upper ] map ;
: quotable? ( ch -- ? )
#! In a string literal, can this character be used without
#! escaping?
dup printable? swap "\"\\" member? not and ; foldable
: url-quotable? ( ch -- ? )
#! In a URL, can this character be used without
#! URL-encoding?
dup letter?
over LETTER? or
over digit? or
swap "/_?." member? or ; foldable