diff options
author | Tony Kelman <tony@kelman.net> | 2015-03-08 15:33:27 -0700 |
---|---|---|
committer | Tony Kelman <tony@kelman.net> | 2015-03-08 17:30:09 -0700 |
commit | a8b688c734d6dac677f7c68a2d915f85baf41b2b (patch) | |
tree | b3a27c9d143df5aeddc4dd38c583024ac9a3da47 | |
parent | 50381b951a2b156c1c236c77d34ac0fddbc0ea46 (diff) | |
download | libutf8proc-a8b688c734d6dac677f7c68a2d915f85baf41b2b.tar.gz libutf8proc-a8b688c734d6dac677f7c68a2d915f85baf41b2b.tar.bz2 |
Minimal cmake build script
move flags for MSVC
rename lump.txt to lump.md, add data/*.txt to .gitignore
-rw-r--r-- | .gitignore | 2 | ||||
-rw-r--r-- | CMakeLists.txt | 22 | ||||
-rw-r--r-- | NEWS.md | 2 | ||||
-rw-r--r-- | lump.md (renamed from lump.txt) | 3 | ||||
-rw-r--r-- | utf8proc.h | 2 | ||||
-rw-r--r-- | utils.cmake | 20 |
6 files changed, 47 insertions, 4 deletions
@@ -8,8 +8,8 @@ *.dll *.dylib *.dSYM -*.txt *.out +data/*.txt bench/bench bench/icu bench/unistring diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100644 index 0000000..4d0c1c3 --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,22 @@ +cmake_minimum_required (VERSION 2.8) + +include (utils.cmake) + +disallow_intree_builds() + +project (utf8proc C) + +add_definitions ( + -DUTF8PROC_EXPORTS +) + +if (NOT MSVC) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O2 -std=c99 -pedantic -Wall") +endif () + +add_library (utf8proc + utf8proc.c + utf8proc.h +) + +set_property (TARGET utf8proc PROPERTY POSITION_INDEPENDENT_CODE ON) @@ -105,7 +105,7 @@ Release of version 1.0.1 2006-09-17: -- added the `LUMP` option, which lumps certain characters together (see `lump.txt`) (also used for the PostgreSQL `unifold` function) +- added the `LUMP` option, which lumps certain characters together (see `lump.md`) (also used for the PostgreSQL `unifold` function) - added the `STRIPMARK` option, which strips marking characters (or marks of composed characters) - deprecated ruby method `String#char_ary` in favour of `String#utf8chars` @@ -1,3 +1,4 @@ +``` U+0020 <-- all space characters (general category Zs) U+0027 ' <-- left/right single quotation mark U+2018..2019, modifier letter apostrophe U+02BC, @@ -23,4 +24,4 @@ U+005F _ <-- all connector characters (general category Pc), U+0060 ` <-- modifier letter grave accent U+02CB U+007C | <-- divides U+2223 U+007E ~ <-- tilde operator U+223C - +``` @@ -140,7 +140,7 @@ extern "C" { * is representing a single grapheme cluster (see UAX#29). * LUMP: Lumps certain characters together * (e.g. HYPHEN U+2010 and MINUS U+2212 to ASCII "-"). - * (See lump.txt for details.) + * (See lump.md for details.) * If NLF2LF is set, this includes a transformation of * paragraph and line separators to ASCII line-feed (LF). * STRIPMARK: Strips all character markings diff --git a/utils.cmake b/utils.cmake new file mode 100644 index 0000000..63fc426 --- /dev/null +++ b/utils.cmake @@ -0,0 +1,20 @@ + +function (disallow_intree_builds) + # Adapted from LLVM's toplevel CMakeLists.txt file + if( CMAKE_SOURCE_DIR STREQUAL CMAKE_BINARY_DIR AND NOT MSVC_IDE ) + message(FATAL_ERROR " + In-source builds are not allowed. CMake would overwrite the + makefiles distributed with utf8proc. Please create a directory + and run cmake from there. Building in a subdirectory is + fine, e.g.: + + mkdir build + cd build + cmake .. + + This process created the file `CMakeCache.txt' and the + directory `CMakeFiles'. Please delete them. + + ") + endif() +endfunction() |