diff options
author | Andreas Rumpf <rumpf_a@web.de> | 2010-02-19 08:34:07 +0100 |
---|---|---|
committer | Andreas Rumpf <rumpf_a@web.de> | 2010-02-19 08:34:07 +0100 |
commit | 64da2f16813bbf03b8a2117d7c4abffd1adf525f (patch) | |
tree | 5fd7ae17a85c43d1aad2475617335d9020ddb136 | |
parent | 0b07b47f69b0b2cf9d08eaa8d302a4472242c5c1 (diff) | |
download | Nim-64da2f16813bbf03b8a2117d7c4abffd1adf525f.tar.gz |
development of graphics module
-rw-r--r-- | lib/impure/graphics.nim | 203 | ||||
-rw-r--r-- | lib/impure/web.nim | 2 | ||||
-rw-r--r-- | lib/newwrap/cairo/cairo.nim | 472 | ||||
-rw-r--r-- | lib/pure/colors.nim (renamed from lib/devel/graphics.nim) | 87 | ||||
-rw-r--r-- | lib/windows/winlean.nim | 3 | ||||
-rw-r--r-- | tools/nimrepl.nim | 12 | ||||
-rw-r--r-- | web/news.txt | 1 |
7 files changed, 508 insertions, 272 deletions
diff --git a/lib/impure/graphics.nim b/lib/impure/graphics.nim new file mode 100644 index 000000000..320339b13 --- /dev/null +++ b/lib/impure/graphics.nim @@ -0,0 +1,203 @@ +# +# +# Nimrod's Runtime Library +# (c) Copyright 2010 Andreas Rumpf +# +# See the file "copying.txt", included in this +# distribution, for details about the copyright. +# + +## This module implements graphical output for Nimrod; the current +## implementation uses SDL but the interface is meant to support multiple +## backends some day. + +import sdl, colors + +type + TRect* = tuple[x, y, width, height: int] + TPoint* = tuple[x, y: int] + + PSurface* = ref TSurface ## a surface to draw onto + TSurface {.pure, final.} = object + w, h: int + s: sdl.PSurface + +proc surfaceFinalizer(s: PSurface) = sdl.freeSurface(s.s) + +proc newSurface*(width, height: int): PSurface = + ## creates a new surface. + new(result, surfaceFinalizer) + result.w = width + result.h = height + result.s = SDL.CreateRGBSurface(SDL.SWSURFACE, width, height, + 32, 0x00FF0000, 0x0000FF00, 0x000000FF, 0xff000000) + +proc textBounds*(text: string): tuple[len, height: int] +proc drawText*(sur: PSurface, p: TPoint, text: string) + +proc writeToPNG*(sur: PSurface, filename: string) = + ## writes the contents of the surface `sur` to the file `filename`. + + +type + TPixels = array[0..1000_000-1, int32] + PPixels = ptr TPixels + +template setPix(video, pitch, x, y, col: expr): expr = + video[y * pitch + x] = col + +template getPix(video, pitch, x, y: expr): expr = + video[y * pitch + x] + +const + ColSize = 4 + +proc getPixel(sur: PSurface, x, y: Natural): TColor = + result = getPix(PPixels(sur.pixels), sur.pitch div ColSize, x, y) + +proc setPixel(sur: PSurface, x, y: Natural; col: TColor) = + setPix(PPixels(sur.pixels), sur.pitch div ColSize, x, y, col) + +proc `[]`*(sur: PSurface, p: TPoint): TColor = + result = getPixel(sur, p.x, p.y) + +proc `[,]`*(sur: PSurface, x, y: int): TColor = + result = setPixel(sur, x, y) + +proc `[]=`*(sur: PSurface, p: TPoint, col: TColor) = + setPixel(sur, p.x, p.y, col) + +proc `[,]=`*(sur: PSurface, x, y: int, col: TColor) = + setPixel(sur, x, y, col) + +proc drawCircle*(sur: PSurface, p: TPoint, r: Natural, color: TColor) = + ## draws a circle with center `p` and radius `r` with the given color + ## onto the surface `sur`. + var video = sur.pixels + var pitch = sur.pitch div ColSize + var p = 1 - r + var py = r + var px = 0 + var x = p.x + var y = p.y + while px <= py + 1: + setPix(video, pitch, x + px, y + py, color) + setPix(video, pitch, x + px, y - py, color) + setPix(video, pitch, x - px, y + py, color) + setPix(video, pitch, x - px, y - py, color) + + setPix(video, pitch, x + py, y + px, color) + setPix(video, pitch, x + py, y - px, color) + setPix(video, pitch, x - py, y + px, color) + setPix(video, pitch, x - py, y - px, color) + + if p < 0: + p = p + (2 * px + 3) + else: + p = p + (2 * (px - py) + 5) + py = py - 1 + px = px + 1 + +proc drawLine*(sur: PSurface, p1, p2: TPoint, color: TColor) = + ## draws a line between the two points `p1` and `p2` with the given color + ## onto the surface `sur`. + var x0: int = p1.x + var x1: int = p2.x + var y0: int = p1.y + var y1: int = p2.y + var dy: int = y1 - y0 + var dx: int = x1 - x0 + if dy < 0: + dy = -dy + stepy = -1 + else: + stepy = 1 + if dx < 0: + dx = -dx + stepx = -1 + else: + stepx = 1 + dy = dy * 2 + dx = dx * 2 + var video = sur.pixels + var pitch = sur.pitch div ColSize + setPix(video, pitch, x0, y0, color) + if dx > dy: + var fraction = dy - (dx div 2) + while x0 != x1: + if fraction >= 0: + y0 = y0 + stepy + fraction = fraction - dx + x0 = x0 + stepx + fraction = fraction + dy + setPix(video, pitch, x0, y0, color) + else: + var fraction = dx - (dy div 2) + while y0 != y1: + if fraction >= 0: + x0 = x0 + stepx + fraction = fraction - dy + y0 = y0 + stepy + fraction = fraction + dx + setPix(video, pitch, x0, y0, color) + +proc drawHorLine*(sur: PSurface, x, y, w: Natural, Color: TColor) = + ## draws a horizontal line from (x,y) to (x+w-1, h). + var video = sur.pixels + var pitch = sur.pitch div ColSize + for i = 0 .. w-1: setPix(video, pitch, x + i, y, color) + +proc drawVerLine*(sur: PSurface, x, y, h: Natural, Color: TColor) = + ## draws a vertical line from (x,y) to (x, y+h-1). + var video = sur.pixels + var pitch = sur.pitch div ColSize + for i in 0 .. h-1: setPix(video, pitch, x, y + i, color) + +proc fillCircle*(s: PSurface, p: TPoint, r: Natural, color: TColor) = + ## draws a circle with center `p` and radius `r` with the given color + ## onto the surface `sur` and fills it. + var p = 1 - r + var py: int = r + var px = 0 + var x = p.x + var y = p.y + while px <= py: + # Fill up the middle half of the circle + DrawVerLine(s, x + px, y, py + 1, color) + DrawVerLine(s, x + px, y - py, py, color) + if px != 0: + DrawVerLine(s, x - px, y, py + 1, color) + DrawVerLine(s, x - px, y - py, py, color) + if p < 0: + p = p + (2 * px + 3) + else: + p = p + (2 * (px - py) + 5) + py = py - 1 + # Fill up the left/right half of the circle + if py >= px: + DrawVerLine(s, x + py + 1, y, px + 1, color) + DrawVerLine(s, x + py + 1, y - px, px, color) + DrawVerLine(s, x - py - 1, y, px + 1, color) + DrawVerLine(s, x - py - 1, y - px, px, color) + px = px + 1 + +proc drawRect*(sur: PSurface, r: TRect, color: TColor) = + ## draws a rectangle. + var video = sur.pixels + var pitch = sur.pitch div ColSize + for i in 0 .. r.w-1: + setPix(video, pitch, r.x + i, r.y, color) + for i in 0 .. r.h-1: + setPix(video, pitch, r.x, r.y + i, color) + setPix(video, pitch, r.x + r.w - 1, r.y + i, color) + for i in 0 .. r.w-1: + setPix(video, pitch, r.x + i, r.y + r.h - 1, color) + +proc fillRect*(sur: PSurface, r: TRect, col: TColor) = + ## draws and fills a rectancle. + var video = sur.pixels + var pitch = sur.pitch div ColSize + for i in r.y..y+r.h-1: + for j in r.x..r.x+r.w-1: + setPix(video, pitch, j, i, color) + diff --git a/lib/impure/web.nim b/lib/impure/web.nim index ba74c285a..db1ec4f1e 100644 --- a/lib/impure/web.nim +++ b/lib/impure/web.nim @@ -17,7 +17,7 @@ ## Currently only requesting URLs is implemented. The implementation depends ## on the libcurl library! ## -## **Deprecated since version 0.8.0:** Use the httpclient module instead. +## **Deprecated since version 0.8.6:** Use the httpclient module instead. ## {.deprecated.} diff --git a/lib/newwrap/cairo/cairo.nim b/lib/newwrap/cairo/cairo.nim index 77b2efa7b..96ad06e4d 100644 --- a/lib/newwrap/cairo/cairo.nim +++ b/lib/newwrap/cairo/cairo.nim @@ -57,13 +57,40 @@ else: type PByte = cstring TStatus* = enum - STATUS_SUCCESS = 0, STATUS_NO_MEMORY, STATUS_INVALID_RESTORE, - STATUS_INVALID_POP_GROUP, STATUS_NO_CURRENT_POINT, STATUS_INVALID_MATRIX, - STATUS_INVALID_STATUS, STATUS_NULL_POINTER, STATUS_INVALID_STRING, - STATUS_INVALID_PATH_DATA, STATUS_READ_ERROR, STATUS_WRITE_ERROR, - STATUS_SURFACE_FINISHED, STATUS_SURFACE_TYPE_MISMATCH, - STATUS_PATTERN_TYPE_MISMATCH, STATUS_INVALID_CONTENT, STATUS_INVALID_FORMAT, - STATUS_INVALID_VISUAL, STATUS_FILE_NOT_FOUND, STATUS_INVALID_DASH + STATUS_SUCCESS = 0, + STATUS_NO_MEMORY, + STATUS_INVALID_RESTORE, + STATUS_INVALID_POP_GROUP, + STATUS_NO_CURRENT_POINT, + STATUS_INVALID_MATRIX, + STATUS_INVALID_STATUS, + STATUS_NULL_POINTER, + STATUS_INVALID_STRING, + STATUS_INVALID_PATH_DATA, + STATUS_READ_ERROR, + STATUS_WRITE_ERROR, + STATUS_SURFACE_FINISHED, + STATUS_SURFACE_TYPE_MISMATCH, + STATUS_PATTERN_TYPE_MISMATCH, + STATUS_INVALID_CONTENT, + STATUS_INVALID_FORMAT, + STATUS_INVALID_VISUAL, + STATUS_FILE_NOT_FOUND, + STATUS_INVALID_DASH, + STATUS_INVALID_DSC_COMMENT, + STATUS_INVALID_INDEX, + STATUS_CLIP_NOT_REPRESENTABLE, + STATUS_TEMP_FILE_ERROR, + STATUS_INVALID_STRIDE, + STATUS_FONT_TYPE_MISMATCH, + STATUS_USER_FONT_IMMUTABLE, + STATUS_USER_FONT_ERROR, + STATUS_NEGATIVE_COUNT, + STATUS_INVALID_CLUSTERS, + STATUS_INVALID_SLANT, + STATUS_INVALID_WEIGHT + + TOperator* = enum OPERATOR_CLEAR, OPERATOR_SOURCE, OPERATOR_OVER, OPERATOR_IN, OPERATOR_OUT, OPERATOR_ATOP, OPERATOR_DEST, OPERATOR_DEST_OVER, OPERATOR_DEST_IN, @@ -114,8 +141,8 @@ type TSvgVersion* = enum SVG_VERSION_1_1, SVG_VERSION_1_2 PSurface* = ptr TSurface - PPCairoSurface* = ptr PSurface - PCairo* = ptr TCario + PPSurface* = ptr PSurface + PContext* = ptr TContext PPattern* = ptr TPattern PFontOptions* = ptr TFontOptions PFontFace* = ptr TFontFace @@ -135,7 +162,7 @@ type TDestroyFunc* = proc (data: Pointer){.cdecl.} TWriteFunc* = proc (closure: Pointer, data: PByte, len: int32): TStatus{.cdecl.} TReadFunc* = proc (closure: Pointer, data: PByte, len: int32): TStatus{.cdecl.} - TCario*{.final.} = object #OPAQUE + TContext*{.final.} = object #OPAQUE TSurface*{.final.} = object #OPAQUE TPattern*{.final.} = object #OPAQUE TScaledFont*{.final.} = object #OPAQUE @@ -198,362 +225,362 @@ proc version_string*(): cstring{.cdecl, importc: "cairo_version_string", #Helper function to retrieve decoded version proc version*(major, minor, micro: var int32) #* Functions for manipulating state objects -proc create*(target: PSurface): PCairo{.cdecl, importc: "cairo_create", +proc create*(target: PSurface): PContext{.cdecl, importc: "cairo_create", dynlib: LIB_CAIRO.} -proc reference*(cr: PCairo): PCairo{.cdecl, importc: "cairo_reference", dynlib: LIB_CAIRO.} -proc destroy*(cr: PCairo){.cdecl, importc: "cairo_destroy", dynlib: LIB_CAIRO.} -proc get_reference_count*(cr: PCairo): int32{.cdecl, +proc reference*(cr: PContext): PContext{.cdecl, importc: "cairo_reference", dynlib: LIB_CAIRO.} +proc destroy*(cr: PContext){.cdecl, importc: "cairo_destroy", dynlib: LIB_CAIRO.} +proc get_reference_count*(cr: PContext): int32{.cdecl, importc: "cairo_get_reference_count", dynlib: LIB_CAIRO.} -proc get_user_data*(cr: PCairo, key: PUserDataKey): pointer{.cdecl, +proc get_user_data*(cr: PContext, key: PUserDataKey): pointer{.cdecl, importc: "cairo_get_user_data", dynlib: LIB_CAIRO.} -proc set_user_data*(cr: PCairo, key: PUserDataKey, user_data: Pointer, +proc set_user_data*(cr: PContext, key: PUserDataKey, user_data: Pointer, destroy: TDestroyFunc): TStatus{.cdecl, importc: "cairo_set_user_data", dynlib: LIB_CAIRO.} -proc save*(cr: PCairo){.cdecl, importc: "cairo_save", dynlib: LIB_CAIRO.} -proc restore*(cr: PCairo){.cdecl, importc: "cairo_restore", dynlib: LIB_CAIRO.} -proc push_group*(cr: PCairo){.cdecl, importc: "cairo_push_group", dynlib: LIB_CAIRO.} -proc push_group_with_content*(cr: PCairo, content: TContent){.cdecl, +proc save*(cr: PContext){.cdecl, importc: "cairo_save", dynlib: LIB_CAIRO.} +proc restore*(cr: PContext){.cdecl, importc: "cairo_restore", dynlib: LIB_CAIRO.} +proc push_group*(cr: PContext){.cdecl, importc: "cairo_push_group", dynlib: LIB_CAIRO.} +proc push_group_with_content*(cr: PContext, content: TContent){.cdecl, importc: "cairo_push_group_with_content", dynlib: LIB_CAIRO.} -proc pop_group*(cr: PCairo): PPattern{.cdecl, importc: "cairo_pop_group", +proc pop_group*(cr: PContext): PPattern{.cdecl, importc: "cairo_pop_group", dynlib: LIB_CAIRO.} -proc pop_group_to_source*(cr: PCairo){.cdecl, importc: "cairo_pop_group_to_source", +proc pop_group_to_source*(cr: PContext){.cdecl, importc: "cairo_pop_group_to_source", dynlib: LIB_CAIRO.} #* Modify state -proc set_operator*(cr: PCairo, op: TOperator){.cdecl, importc: "cairo_set_operator", +proc set_operator*(cr: PContext, op: TOperator){.cdecl, importc: "cairo_set_operator", dynlib: LIB_CAIRO.} -proc set_source*(cr: PCairo, source: PPattern){.cdecl, importc: "cairo_set_source", +proc set_source*(cr: PContext, source: PPattern){.cdecl, importc: "cairo_set_source", dynlib: LIB_CAIRO.} -proc set_source_rgb*(cr: PCairo, red, green, blue: float64){.cdecl, +proc set_source_rgb*(cr: PContext, red, green, blue: float64){.cdecl, importc: "cairo_set_source_rgb", dynlib: LIB_CAIRO.} -proc set_source_rgba*(cr: PCairo, red, green, blue, alpha: float64){.cdecl, +proc set_source_rgba*(cr: PContext, red, green, blue, alpha: float64){.cdecl, importc: "cairo_set_source_rgba", dynlib: LIB_CAIRO.} -proc set_source_surface*(cr: PCairo, surface: PSurface, x, y: float64){.cdecl, +proc set_source*(cr: PContext, surface: PSurface, x, y: float64){.cdecl, importc: "cairo_set_source_surface", dynlib: LIB_CAIRO.} -proc set_tolerance*(cr: PCairo, tolerance: float64){.cdecl, +proc set_tolerance*(cr: PContext, tolerance: float64){.cdecl, importc: "cairo_set_tolerance", dynlib: LIB_CAIRO.} -proc set_antialias*(cr: PCairo, antialias: TAntialias){.cdecl, +proc set_antialias*(cr: PContext, antialias: TAntialias){.cdecl, importc: "cairo_set_antialias", dynlib: LIB_CAIRO.} -proc set_fill_rule*(cr: PCairo, fill_rule: TFillRule){.cdecl, +proc set_fill_rule*(cr: PContext, fill_rule: TFillRule){.cdecl, importc: "cairo_set_fill_rule", dynlib: LIB_CAIRO.} -proc set_line_width*(cr: PCairo, width: float64){.cdecl, +proc set_line_width*(cr: PContext, width: float64){.cdecl, importc: "cairo_set_line_width", dynlib: LIB_CAIRO.} -proc set_line_cap*(cr: PCairo, line_cap: TLineCap){.cdecl, +proc set_line_cap*(cr: PContext, line_cap: TLineCap){.cdecl, importc: "cairo_set_line_cap", dynlib: LIB_CAIRO.} -proc set_line_join*(cr: PCairo, line_join: TLineJoin){.cdecl, +proc set_line_join*(cr: PContext, line_join: TLineJoin){.cdecl, importc: "cairo_set_line_join", dynlib: LIB_CAIRO.} -proc set_dash*(cr: PCairo, dashes: openarray[float64], offset: float64){.cdecl, +proc set_dash*(cr: PContext, dashes: openarray[float64], offset: float64){.cdecl, importc: "cairo_set_dash", dynlib: LIB_CAIRO.} -proc set_miter_limit*(cr: PCairo, limit: float64){.cdecl, +proc set_miter_limit*(cr: PContext, limit: float64){.cdecl, importc: "cairo_set_miter_limit", dynlib: LIB_CAIRO.} -proc translate*(cr: PCairo, tx, ty: float64){.cdecl, importc: "cairo_translate", +proc translate*(cr: PContext, tx, ty: float64){.cdecl, importc: "cairo_translate", dynlib: LIB_CAIRO.} -proc scale*(cr: PCairo, sx, sy: float64){.cdecl, importc: "cairo_scale", +proc scale*(cr: PContext, sx, sy: float64){.cdecl, importc: "cairo_scale", dynlib: LIB_CAIRO.} -proc rotate*(cr: PCairo, angle: float64){.cdecl, importc: "cairo_rotate", +proc rotate*(cr: PContext, angle: float64){.cdecl, importc: "cairo_rotate", dynlib: LIB_CAIRO.} -proc transform*(cr: PCairo, matrix: PMatrix){.cdecl, importc: "cairo_transform", +proc transform*(cr: PContext, matrix: PMatrix){.cdecl, importc: "cairo_transform", dynlib: LIB_CAIRO.} -proc set_matrix*(cr: PCairo, matrix: PMatrix){.cdecl, importc: "cairo_set_matrix", +proc set_matrix*(cr: PContext, matrix: PMatrix){.cdecl, importc: "cairo_set_matrix", dynlib: LIB_CAIRO.} -proc identity_matrix*(cr: PCairo){.cdecl, importc: "cairo_identity_matrix", +proc identity_matrix*(cr: PContext){.cdecl, importc: "cairo_identity_matrix", dynlib: LIB_CAIRO.} -proc user_to_device*(cr: PCairo, x, y: var float64){.cdecl, +proc user_to_device*(cr: PContext, x, y: var float64){.cdecl, importc: "cairo_user_to_device", dynlib: LIB_CAIRO.} -proc user_to_device_distance*(cr: PCairo, dx, dy: var float64){.cdecl, +proc user_to_device_distance*(cr: PContext, dx, dy: var float64){.cdecl, importc: "cairo_user_to_device_distance", dynlib: LIB_CAIRO.} -proc device_to_user*(cr: PCairo, x, y: var float64){.cdecl, +proc device_to_user*(cr: PContext, x, y: var float64){.cdecl, importc: "cairo_device_to_user", dynlib: LIB_CAIRO.} -proc device_to_user_distance*(cr: PCairo, dx, dy: var float64){.cdecl, +proc device_to_user_distance*(cr: PContext, dx, dy: var float64){.cdecl, importc: "cairo_device_to_user_distance", dynlib: LIB_CAIRO.} #* Path creation functions -proc new_path*(cr: PCairo){.cdecl, importc: "cairo_new_path", dynlib: LIB_CAIRO.} -proc move_to*(cr: PCairo, x, y: float64){.cdecl, importc: "cairo_move_to", +proc new_path*(cr: PContext){.cdecl, importc: "cairo_new_path", dynlib: LIB_CAIRO.} +proc move_to*(cr: PContext, x, y: float64){.cdecl, importc: "cairo_move_to", dynlib: LIB_CAIRO.} -proc new_sub_path*(cr: PCairo){.cdecl, importc: "cairo_new_sub_path", +proc new_sub_path*(cr: PContext){.cdecl, importc: "cairo_new_sub_path", dynlib: LIB_CAIRO.} -proc line_to*(cr: PCairo, x, y: float64){.cdecl, importc: "cairo_line_to", +proc line_to*(cr: PContext, x, y: float64){.cdecl, importc: "cairo_line_to", dynlib: LIB_CAIRO.} -proc curve_to*(cr: PCairo, x1, y1, x2, y2, x3, y3: float64){.cdecl, +proc curve_to*(cr: PContext, x1, y1, x2, y2, x3, y3: float64){.cdecl, importc: "cairo_curve_to", dynlib: LIB_CAIRO.} -proc arc*(cr: PCairo, xc, yc, radius, angle1, angle2: float64){.cdecl, +proc arc*(cr: PContext, xc, yc, radius, angle1, angle2: float64){.cdecl, importc: "cairo_arc", dynlib: LIB_CAIRO.} -proc arc_negative*(cr: PCairo, xc, yc, radius, angle1, angle2: float64){.cdecl, +proc arc_negative*(cr: PContext, xc, yc, radius, angle1, angle2: float64){.cdecl, importc: "cairo_arc_negative", dynlib: LIB_CAIRO.} -proc rel_move_to*(cr: PCairo, dx, dy: float64){.cdecl, importc: "cairo_rel_move_to", +proc rel_move_to*(cr: PContext, dx, dy: float64){.cdecl, importc: "cairo_rel_move_to", dynlib: LIB_CAIRO.} -proc rel_line_to*(cr: PCairo, dx, dy: float64){.cdecl, importc: "cairo_rel_line_to", +proc rel_line_to*(cr: PContext, dx, dy: float64){.cdecl, importc: "cairo_rel_line_to", dynlib: LIB_CAIRO.} -proc rel_curve_to*(cr: PCairo, dx1, dy1, dx2, dy2, dx3, dy3: float64){.cdecl, +proc rel_curve_to*(cr: PContext, dx1, dy1, dx2, dy2, dx3, dy3: float64){.cdecl, importc: "cairo_rel_curve_to", dynlib: LIB_CAIRO.} -proc rectangle*(cr: PCairo, x, y, width, height: float64){.cdecl, +proc rectangle*(cr: PContext, x, y, width, height: float64){.cdecl, importc: "cairo_rectangle", dynlib: LIB_CAIRO.} -proc close_path*(cr: PCairo){.cdecl, importc: "cairo_close_path", dynlib: LIB_CAIRO.} +proc close_path*(cr: PContext){.cdecl, importc: "cairo_close_path", dynlib: LIB_CAIRO.} #* Painting functions -proc paint*(cr: PCairo){.cdecl, importc: "cairo_paint", dynlib: LIB_CAIRO.} -proc paint_with_alpha*(cr: PCairo, alpha: float64){.cdecl, +proc paint*(cr: PContext){.cdecl, importc: "cairo_paint", dynlib: LIB_CAIRO.} +proc paint_with_alpha*(cr: PContext, alpha: float64){.cdecl, importc: "cairo_paint_with_alpha", dynlib: LIB_CAIRO.} -proc mask*(cr: PCairo, pattern: PPattern){.cdecl, importc: "cairo_mask", +proc mask*(cr: PContext, pattern: PPattern){.cdecl, importc: "cairo_mask", dynlib: LIB_CAIRO.} -proc mask_surface*(cr: PCairo, surface: PSurface, surface_x, surface_y: float64){. +proc mask*(cr: PContext, surface: PSurface, surface_x, surface_y: float64){. cdecl, importc: "cairo_mask_surface", dynlib: LIB_CAIRO.} -proc stroke*(cr: PCairo){.cdecl, importc: "cairo_stroke", dynlib: LIB_CAIRO.} -proc stroke_preserve*(cr: PCairo){.cdecl, importc: "cairo_stroke_preserve", +proc stroke*(cr: PContext){.cdecl, importc: "cairo_stroke", dynlib: LIB_CAIRO.} +proc stroke_preserve*(cr: PContext){.cdecl, importc: "cairo_stroke_preserve", dynlib: LIB_CAIRO.} -proc fill*(cr: PCairo){.cdecl, importc: "cairo_fill", dynlib: LIB_CAIRO.} -proc fill_preserve*(cr: PCairo){.cdecl, importc: "cairo_fill_preserve", +proc fill*(cr: PContext){.cdecl, importc: "cairo_fill", dynlib: LIB_CAIRO.} +proc fill_preserve*(cr: PContext){.cdecl, importc: "cairo_fill_preserve", dynlib: LIB_CAIRO.} -proc copy_page*(cr: PCairo){.cdecl, importc: "cairo_copy_page", dynlib: LIB_CAIRO.} -proc show_page*(cr: PCairo){.cdecl, importc: "cairo_show_page", dynlib: LIB_CAIRO.} +proc copy_page*(cr: PContext){.cdecl, importc: "cairo_copy_page", dynlib: LIB_CAIRO.} +proc show_page*(cr: PContext){.cdecl, importc: "cairo_show_page", dynlib: LIB_CAIRO.} #* Insideness testing -proc in_stroke*(cr: PCairo, x, y: float64): TBool{.cdecl, importc: "cairo_in_stroke", +proc in_stroke*(cr: PContext, x, y: float64): TBool{.cdecl, importc: "cairo_in_stroke", dynlib: LIB_CAIRO.} -proc in_fill*(cr: PCairo, x, y: float64): TBool{.cdecl, importc: "cairo_in_fill", +proc in_fill*(cr: PContext, x, y: float64): TBool{.cdecl, importc: "cairo_in_fill", dynlib: LIB_CAIRO.} #* Rectangular extents -proc stroke_extents*(cr: PCairo, x1, y1, x2, y2: var float64){.cdecl, +proc stroke_extents*(cr: PContext, x1, y1, x2, y2: var float64){.cdecl, importc: "cairo_stroke_extents", dynlib: LIB_CAIRO.} -proc fill_extents*(cr: PCairo, x1, y1, x2, y2: var float64){.cdecl, +proc fill_extents*(cr: PContext, x1, y1, x2, y2: var float64){.cdecl, importc: "cairo_fill_extents", dynlib: LIB_CAIRO.} #* Clipping -proc reset_clip*(cr: PCairo){.cdecl, importc: "cairo_reset_clip", dynlib: LIB_CAIRO.} -proc clip*(cr: PCairo){.cdecl, importc: "cairo_clip", dynlib: LIB_CAIRO.} -proc clip_preserve*(cr: PCairo){.cdecl, importc: "cairo_clip_preserve", +proc reset_clip*(cr: PContext){.cdecl, importc: "cairo_reset_clip", dynlib: LIB_CAIRO.} +proc clip*(cr: PContext){.cdecl, importc: "cairo_clip", dynlib: LIB_CAIRO.} +proc clip_preserve*(cr: PContext){.cdecl, importc: "cairo_clip_preserve", dynlib: LIB_CAIRO.} -proc clip_extents*(cr: PCairo, x1, y1, x2, y2: var float64){.cdecl, +proc clip_extents*(cr: PContext, x1, y1, x2, y2: var float64){.cdecl, importc: "cairo_clip_extents", dynlib: LIB_CAIRO.} -proc copy_clip_rectangle_list*(cr: PCairo): PRectangleList{.cdecl, +proc copy_clip_rectangle_list*(cr: PContext): PRectangleList{.cdecl, importc: "cairo_copy_clip_rectangle_list", dynlib: LIB_CAIRO.} proc rectangle_list_destroy*(rectangle_list: PRectangleList){.cdecl, importc: "cairo_rectangle_list_destroy", dynlib: LIB_CAIRO.} #* Font/Text functions proc font_options_create*(): PFontOptions{.cdecl, importc: "cairo_font_options_create", dynlib: LIB_CAIRO.} -proc font_options_copy*(original: PFontOptions): PFontOptions{.cdecl, +proc copy*(original: PFontOptions): PFontOptions{.cdecl, importc: "cairo_font_options_copy", dynlib: LIB_CAIRO.} -proc font_options_destroy*(options: PFontOptions){.cdecl, +proc destroy*(options: PFontOptions){.cdecl, importc: "cairo_font_options_destroy", dynlib: LIB_CAIRO.} -proc font_options_status*(options: PFontOptions): TStatus{.cdecl, +proc status*(options: PFontOptions): TStatus{.cdecl, importc: "cairo_font_options_status", dynlib: LIB_CAIRO.} -proc font_options_merge*(options, other: PFontOptions){.cdecl, +proc merge*(options, other: PFontOptions){.cdecl, importc: "cairo_font_options_merge", dynlib: LIB_CAIRO.} -proc font_options_equal*(options, other: PFontOptions): TBool{.cdecl, +proc equal*(options, other: PFontOptions): TBool{.cdecl, importc: "cairo_font_options_equal", dynlib: LIB_CAIRO.} -proc font_options_hash*(options: PFontOptions): int32{.cdecl, +proc hash*(options: PFontOptions): int32{.cdecl, importc: "cairo_font_options_hash", dynlib: LIB_CAIRO.} -proc font_options_set_antialias*(options: PFontOptions, antialias: TAntialias){. +proc set_antialias*(options: PFontOptions, antialias: TAntialias){. cdecl, importc: "cairo_font_options_set_antialias", dynlib: LIB_CAIRO.} -proc font_options_get_antialias*(options: PFontOptions): TAntialias{.cdecl, +proc get_antialias*(options: PFontOptions): TAntialias{.cdecl, importc: "cairo_font_options_get_antialias", dynlib: LIB_CAIRO.} -proc font_options_set_subpixel_order*(options: PFontOptions, +proc set_subpixel_order*(options: PFontOptions, subpixel_order: TSubpixelOrder){.cdecl, importc: "cairo_font_options_set_subpixel_order", dynlib: LIB_CAIRO.} -proc font_options_get_subpixel_order*(options: PFontOptions): TSubpixelOrder{. +proc get_subpixel_order*(options: PFontOptions): TSubpixelOrder{. cdecl, importc: "cairo_font_options_get_subpixel_order", dynlib: LIB_CAIRO.} -proc font_options_set_hint_style*(options: PFontOptions, hint_style: THintStyle){. +proc set_hint_style*(options: PFontOptions, hint_style: THintStyle){. cdecl, importc: "cairo_font_options_set_hint_style", dynlib: LIB_CAIRO.} -proc font_options_get_hint_style*(options: PFontOptions): THintStyle{.cdecl, +proc get_hint_style*(options: PFontOptions): THintStyle{.cdecl, importc: "cairo_font_options_get_hint_style", dynlib: LIB_CAIRO.} -proc font_options_set_hint_metrics*(options: PFontOptions, +proc set_hint_metrics*(options: PFontOptions, hint_metrics: THintMetrics){.cdecl, importc: "cairo_font_options_set_hint_metrics", dynlib: LIB_CAIRO.} -proc font_options_get_hint_metrics*(options: PFontOptions): THintMetrics{.cdecl, +proc get_hint_metrics*(options: PFontOptions): THintMetrics{.cdecl, importc: "cairo_font_options_get_hint_metrics", dynlib: LIB_CAIRO.} #* This interface is for dealing with text as text, not caring about the # font object inside the the TCairo. -proc select_font_face*(cr: PCairo, family: cstring, slant: TFontSlant, +proc select_font_face*(cr: PContext, family: cstring, slant: TFontSlant, weight: TFontWeight){.cdecl, importc: "cairo_select_font_face", dynlib: LIB_CAIRO.} -proc set_font_size*(cr: PCairo, size: float64){.cdecl, +proc set_font_size*(cr: PContext, size: float64){.cdecl, importc: "cairo_set_font_size", dynlib: LIB_CAIRO.} -proc set_font_matrix*(cr: PCairo, matrix: PMatrix){.cdecl, +proc set_font_matrix*(cr: PContext, matrix: PMatrix){.cdecl, importc: "cairo_set_font_matrix", dynlib: LIB_CAIRO.} -proc get_font_matrix*(cr: PCairo, matrix: PMatrix){.cdecl, +proc get_font_matrix*(cr: PContext, matrix: PMatrix){.cdecl, importc: "cairo_get_font_matrix", dynlib: LIB_CAIRO.} -proc set_font_options*(cr: PCairo, options: PFontOptions){.cdecl, +proc set_font_options*(cr: PContext, options: PFontOptions){.cdecl, importc: "cairo_set_font_options", dynlib: LIB_CAIRO.} -proc get_font_options*(cr: PCairo, options: PFontOptions){.cdecl, +proc get_font_options*(cr: PContext, options: PFontOptions){.cdecl, importc: "cairo_get_font_options", dynlib: LIB_CAIRO.} -proc set_font_face*(cr: PCairo, font_face: PFontFace){.cdecl, +proc set_font_face*(cr: PContext, font_face: PFontFace){.cdecl, importc: "cairo_set_font_face", dynlib: LIB_CAIRO.} -proc get_font_face*(cr: PCairo): PFontFace{.cdecl, importc: "cairo_get_font_face", +proc get_font_face*(cr: PContext): PFontFace{.cdecl, importc: "cairo_get_font_face", dynlib: LIB_CAIRO.} -proc set_scaled_font*(cr: PCairo, scaled_font: PScaledFont){.cdecl, +proc set_scaled_font*(cr: PContext, scaled_font: PScaledFont){.cdecl, importc: "cairo_set_scaled_font", dynlib: LIB_CAIRO.} -proc get_scaled_font*(cr: PCairo): PScaledFont{.cdecl, +proc get_scaled_font*(cr: PContext): PScaledFont{.cdecl, importc: "cairo_get_scaled_font", dynlib: LIB_CAIRO.} -proc show_text*(cr: PCairo, utf8: cstring){.cdecl, importc: "cairo_show_text", +proc show_text*(cr: PContext, utf8: cstring){.cdecl, importc: "cairo_show_text", dynlib: LIB_CAIRO.} -proc show_glyphs*(cr: PCairo, glyphs: PGlyph, num_glyphs: int32){.cdecl, +proc show_glyphs*(cr: PContext, glyphs: PGlyph, num_glyphs: int32){.cdecl, importc: "cairo_show_glyphs", dynlib: LIB_CAIRO.} -proc text_path*(cr: PCairo, utf8: cstring){.cdecl, importc: "cairo_text_path", +proc text_path*(cr: PContext, utf8: cstring){.cdecl, importc: "cairo_text_path", dynlib: LIB_CAIRO.} -proc glyph_path*(cr: PCairo, glyphs: PGlyph, num_glyphs: int32){.cdecl, +proc glyph_path*(cr: PContext, glyphs: PGlyph, num_glyphs: int32){.cdecl, importc: "cairo_glyph_path", dynlib: LIB_CAIRO.} -proc text_extents*(cr: PCairo, utf8: cstring, extents: PTextExtents){.cdecl, +proc text_extents*(cr: PContext, utf8: cstring, extents: PTextExtents){.cdecl, importc: "cairo_text_extents", dynlib: LIB_CAIRO.} -proc glyph_extents*(cr: PCairo, glyphs: PGlyph, num_glyphs: int32, +proc glyph_extents*(cr: PContext, glyphs: PGlyph, num_glyphs: int32, extents: PTextExtents){.cdecl, importc: "cairo_glyph_extents", dynlib: LIB_CAIRO.} -proc font_extents*(cr: PCairo, extents: PFontExtents){.cdecl, +proc font_extents*(cr: PContext, extents: PFontExtents){.cdecl, importc: "cairo_font_extents", dynlib: LIB_CAIRO.} #* Generic identifier for a font style -proc font_face_reference*(font_face: PFontFace): PFontFace{.cdecl, +proc reference*(font_face: PFontFace): PFontFace{.cdecl, importc: "cairo_font_face_reference", dynlib: LIB_CAIRO.} -proc font_face_destroy*(font_face: PFontFace){.cdecl, +proc destroy*(font_face: PFontFace){.cdecl, importc: "cairo_font_face_destroy", dynlib: LIB_CAIRO.} -proc font_face_get_reference_count*(font_face: PFontFace): int32{.cdecl, +proc get_reference_count*(font_face: PFontFace): int32{.cdecl, importc: "cairo_font_face_get_reference_count", dynlib: LIB_CAIRO.} -proc font_face_status*(font_face: PFontFace): TStatus{.cdecl, +proc status*(font_face: PFontFace): TStatus{.cdecl, importc: "cairo_font_face_status", dynlib: LIB_CAIRO.} -proc font_face_get_type*(font_face: PFontFace): TFontType{.cdecl, +proc get_type*(font_face: PFontFace): TFontType{.cdecl, importc: "cairo_font_face_get_type", dynlib: LIB_CAIRO.} -proc font_face_get_user_data*(font_face: PFontFace, key: PUserDataKey): pointer{. +proc get_user_data*(font_face: PFontFace, key: PUserDataKey): pointer{. cdecl, importc: "cairo_font_face_get_user_data", dynlib: LIB_CAIRO.} -proc font_face_set_user_data*(font_face: PFontFace, key: PUserDataKey, - user_data: pointer, destroy: TDestroyFunc): TStatus{. +proc set_user_data*(font_face: PFontFace, key: PUserDataKey, + user_data: pointer, destroy: TDestroyFunc): TStatus{. cdecl, importc: "cairo_font_face_set_user_data", dynlib: LIB_CAIRO.} #* Portable interface to general font features proc scaled_font_create*(font_face: PFontFace, font_matrix: PMatrix, ctm: PMatrix, options: PFontOptions): PScaledFont{. cdecl, importc: "cairo_scaled_font_create", dynlib: LIB_CAIRO.} -proc scaled_font_reference*(scaled_font: PScaledFont): PScaledFont{.cdecl, +proc reference*(scaled_font: PScaledFont): PScaledFont{.cdecl, importc: "cairo_scaled_font_reference", dynlib: LIB_CAIRO.} -proc scaled_font_destroy*(scaled_font: PScaledFont){.cdecl, +proc destroy*(scaled_font: PScaledFont){.cdecl, importc: "cairo_scaled_font_destroy", dynlib: LIB_CAIRO.} -proc scaled_font_get_reference_count*(scaled_font: PScaledFont): int32{.cdecl, +proc get_reference_count*(scaled_font: PScaledFont): int32{.cdecl, importc: "cairo_scaled_font_get_reference_count", dynlib: LIB_CAIRO.} -proc scaled_font_status*(scaled_font: PScaledFont): TStatus{.cdecl, +proc status*(scaled_font: PScaledFont): TStatus{.cdecl, importc: "cairo_scaled_font_status", dynlib: LIB_CAIRO.} -proc scaled_font_get_type*(scaled_font: PScaledFont): TFontType{.cdecl, +proc get_type*(scaled_font: PScaledFont): TFontType{.cdecl, importc: "cairo_scaled_font_get_type", dynlib: LIB_CAIRO.} -proc scaled_font_get_user_data*(scaled_font: PScaledFont, key: PUserDataKey): Pointer{. +proc get_user_data*(scaled_font: PScaledFont, key: PUserDataKey): Pointer{. cdecl, importc: "cairo_scaled_font_get_user_data", dynlib: LIB_CAIRO.} -proc scaled_font_set_user_data*(scaled_font: PScaledFont, key: PUserDataKey, - user_data: Pointer, destroy: TDestroyFunc): TStatus{. +proc set_user_data*(scaled_font: PScaledFont, key: PUserDataKey, + user_data: Pointer, destroy: TDestroyFunc): TStatus{. cdecl, importc: "cairo_scaled_font_set_user_data", dynlib: LIB_CAIRO.} -proc scaled_font_extents*(scaled_font: PScaledFont, extents: PFontExtents){. +proc extents*(scaled_font: PScaledFont, extents: PFontExtents){. cdecl, importc: "cairo_scaled_font_extents", dynlib: LIB_CAIRO.} -proc scaled_font_text_extents*(scaled_font: PScaledFont, utf8: cstring, - extents: PTextExtents){.cdecl, +proc text_extents*(scaled_font: PScaledFont, utf8: cstring, + extents: PTextExtents){.cdecl, importc: "cairo_scaled_font_text_extents", dynlib: LIB_CAIRO.} -proc scaled_font_glyph_extents*(scaled_font: PScaledFont, glyphs: PGlyph, +proc glyph_extents*(scaled_font: PScaledFont, glyphs: PGlyph, num_glyphs: int32, extents: PTextExtents){. cdecl, importc: "cairo_scaled_font_glyph_extents", dynlib: LIB_CAIRO.} -proc scaled_font_get_font_face*(scaled_font: PScaledFont): PFontFace{.cdecl, +proc get_font_face*(scaled_font: PScaledFont): PFontFace{.cdecl, importc: "cairo_scaled_font_get_font_face", dynlib: LIB_CAIRO.} -proc scaled_font_get_font_matrix*(scaled_font: PScaledFont, font_matrix: PMatrix){. +proc get_font_matrix*(scaled_font: PScaledFont, font_matrix: PMatrix){. cdecl, importc: "cairo_scaled_font_get_font_matrix", dynlib: LIB_CAIRO.} -proc scaled_font_get_ctm*(scaled_font: PScaledFont, ctm: PMatrix){.cdecl, +proc get_ctm*(scaled_font: PScaledFont, ctm: PMatrix){.cdecl, importc: "cairo_scaled_font_get_ctm", dynlib: LIB_CAIRO.} -proc scaled_font_get_font_options*(scaled_font: PScaledFont, +proc get_font_options*(scaled_font: PScaledFont, options: PFontOptions){.cdecl, importc: "cairo_scaled_font_get_font_options", dynlib: LIB_CAIRO.} #* Query functions -proc get_operator*(cr: PCairo): TOperator{.cdecl, importc: "cairo_get_operator", +proc get_operator*(cr: PContext): TOperator{.cdecl, importc: "cairo_get_operator", dynlib: LIB_CAIRO.} -proc get_source*(cr: PCairo): PPattern{.cdecl, importc: "cairo_get_source", +proc get_source*(cr: PContext): PPattern{.cdecl, importc: "cairo_get_source", dynlib: LIB_CAIRO.} -proc get_tolerance*(cr: PCairo): float64{.cdecl, importc: "cairo_get_tolerance", +proc get_tolerance*(cr: PContext): float64{.cdecl, importc: "cairo_get_tolerance", dynlib: LIB_CAIRO.} -proc get_antialias*(cr: PCairo): TAntialias{.cdecl, importc: "cairo_get_antialias", +proc get_antialias*(cr: PContext): TAntialias{.cdecl, importc: "cairo_get_antialias", dynlib: LIB_CAIRO.} -proc get_current_point*(cr: PCairo, x, y: var float64){.cdecl, +proc get_current_point*(cr: PContext, x, y: var float64){.cdecl, importc: "cairo_get_current_point", dynlib: LIB_CAIRO.} -proc get_fill_rule*(cr: PCairo): TFillRule{.cdecl, importc: "cairo_get_fill_rule", +proc get_fill_rule*(cr: PContext): TFillRule{.cdecl, importc: "cairo_get_fill_rule", dynlib: LIB_CAIRO.} -proc get_line_width*(cr: PCairo): float64{.cdecl, importc: "cairo_get_line_width", +proc get_line_width*(cr: PContext): float64{.cdecl, importc: "cairo_get_line_width", dynlib: LIB_CAIRO.} -proc get_line_cap*(cr: PCairo): TLineCap{.cdecl, importc: "cairo_get_line_cap", +proc get_line_cap*(cr: PContext): TLineCap{.cdecl, importc: "cairo_get_line_cap", dynlib: LIB_CAIRO.} -proc get_line_join*(cr: PCairo): TLineJoin{.cdecl, importc: "cairo_get_line_join", +proc get_line_join*(cr: PContext): TLineJoin{.cdecl, importc: "cairo_get_line_join", dynlib: LIB_CAIRO.} -proc get_miter_limit*(cr: PCairo): float64{.cdecl, importc: "cairo_get_miter_limit", +proc get_miter_limit*(cr: PContext): float64{.cdecl, importc: "cairo_get_miter_limit", dynlib: LIB_CAIRO.} -proc get_dash_count*(cr: PCairo): int32{.cdecl, importc: "cairo_get_dash_count", +proc get_dash_count*(cr: PContext): int32{.cdecl, importc: "cairo_get_dash_count", dynlib: LIB_CAIRO.} -proc get_dash*(cr: PCairo, dashes, offset: var float64){.cdecl, +proc get_dash*(cr: PContext, dashes, offset: var float64){.cdecl, importc: "cairo_get_dash", dynlib: LIB_CAIRO.} -proc get_matrix*(cr: PCairo, matrix: PMatrix){.cdecl, importc: "cairo_get_matrix", +proc get_matrix*(cr: PContext, matrix: PMatrix){.cdecl, importc: "cairo_get_matrix", dynlib: LIB_CAIRO.} -proc get_target*(cr: PCairo): PSurface{.cdecl, importc: "cairo_get_target", +proc get_target*(cr: PContext): PSurface{.cdecl, importc: "cairo_get_target", dynlib: LIB_CAIRO.} -proc get_group_target*(cr: PCairo): PSurface{.cdecl, +proc get_group_target*(cr: PContext): PSurface{.cdecl, importc: "cairo_get_group_target", dynlib: LIB_CAIRO.} -proc copy_path*(cr: PCairo): PPath{.cdecl, importc: "cairo_copy_path", +proc copy_path*(cr: PContext): PPath{.cdecl, importc: "cairo_copy_path", dynlib: LIB_CAIRO.} -proc copy_path_flat*(cr: PCairo): PPath{.cdecl, importc: "cairo_copy_path_flat", +proc copy_path_flat*(cr: PContext): PPath{.cdecl, importc: "cairo_copy_path_flat", dynlib: LIB_CAIRO.} -proc append_path*(cr: PCairo, path: PPath){.cdecl, importc: "cairo_append_path", +proc append_path*(cr: PContext, path: PPath){.cdecl, importc: "cairo_append_path", dynlib: LIB_CAIRO.} -proc path_destroy*(path: PPath){.cdecl, importc: "cairo_path_destroy", +proc destroy*(path: PPath){.cdecl, importc: "cairo_path_destroy", dynlib: LIB_CAIRO.} #* Error status queries -proc status*(cr: PCairo): TStatus{.cdecl, importc: "cairo_status", dynlib: LIB_CAIRO.} +proc status*(cr: PContext): TStatus{.cdecl, importc: "cairo_status", dynlib: LIB_CAIRO.} proc status_to_string*(status: TStatus): cstring{.cdecl, importc: "cairo_status_to_string", dynlib: LIB_CAIRO.} #* Surface manipulation proc surface_create_similar*(other: PSurface, content: TContent, width, height: int32): PSurface{.cdecl, importc: "cairo_surface_create_similar", dynlib: LIB_CAIRO.} -proc surface_reference*(surface: PSurface): PSurface{.cdecl, +proc reference*(surface: PSurface): PSurface{.cdecl, importc: "cairo_surface_reference", dynlib: LIB_CAIRO.} -proc surface_finish*(surface: PSurface){.cdecl, importc: "cairo_surface_finish", +proc finish*(surface: PSurface){.cdecl, importc: "cairo_surface_finish", dynlib: LIB_CAIRO.} -proc surface_destroy*(surface: PSurface){.cdecl, +proc destroy*(surface: PSurface){.cdecl, importc: "cairo_surface_destroy", dynlib: LIB_CAIRO.} -proc surface_get_reference_count*(surface: PSurface): int32{.cdecl, +proc get_reference_count*(surface: PSurface): int32{.cdecl, importc: "cairo_surface_get_reference_count", dynlib: LIB_CAIRO.} -proc surface_status*(surface: PSurface): TStatus{.cdecl, +proc status*(surface: PSurface): TStatus{.cdecl, importc: "cairo_surface_status", dynlib: LIB_CAIRO.} -proc surface_get_type*(surface: PSurface): TSurfaceType{.cdecl, +proc get_type*(surface: PSurface): TSurfaceType{.cdecl, importc: "cairo_surface_get_type", dynlib: LIB_CAIRO.} -proc surface_get_content*(surface: PSurface): TContent{.cdecl, +proc get_content*(surface: PSurface): TContent{.cdecl, importc: "cairo_surface_get_content", dynlib: LIB_CAIRO.} -proc surface_write_to_png*(surface: PSurface, filename: cstring): TStatus{. +proc write_to_png*(surface: PSurface, filename: cstring): TStatus{. cdecl, importc: "cairo_surface_write_to_png", dynlib: LIB_CAIRO.} -proc surface_write_to_png_stream*(surface: PSurface, write_func: TWriteFunc, - closure: pointer): TStatus{.cdecl, +proc write_to_png*(surface: PSurface, write_func: TWriteFunc, + closure: pointer): TStatus{.cdecl, importc: "cairo_surface_write_to_png_stream", dynlib: LIB_CAIRO.} -proc surface_get_user_data*(surface: PSurface, key: PUserDataKey): pointer{. +proc get_user_data*(surface: PSurface, key: PUserDataKey): pointer{. cdecl, importc: "cairo_surface_get_user_data", dynlib: LIB_CAIRO.} -proc surface_set_user_data*(surface: PSurface, key: PUserDataKey, +proc set_user_data*(surface: PSurface, key: PUserDataKey, user_data: pointer, destroy: TDestroyFunc): TStatus{. cdecl, importc: "cairo_surface_set_user_data", dynlib: LIB_CAIRO.} -proc surface_get_font_options*(surface: PSurface, options: PFontOptions){.cdecl, +proc get_font_options*(surface: PSurface, options: PFontOptions){.cdecl, importc: "cairo_surface_get_font_options", dynlib: LIB_CAIRO.} -proc surface_flush*(surface: PSurface){.cdecl, importc: "cairo_surface_flush", +proc flush*(surface: PSurface){.cdecl, importc: "cairo_surface_flush", dynlib: LIB_CAIRO.} -proc surface_mark_dirty*(surface: PSurface){.cdecl, +proc mark_dirty*(surface: PSurface){.cdecl, importc: "cairo_surface_mark_dirty", dynlib: LIB_CAIRO.} -proc surface_mark_dirty_rectangle*(surface: PSurface, x, y, width, height: int32){. +proc mark_dirty_rectangle*(surface: PSurface, x, y, width, height: int32){. cdecl, importc: "cairo_surface_mark_dirty_rectangle", dynlib: LIB_CAIRO.} -proc surface_set_device_offset*(surface: PSurface, x_offset, y_offset: float64){. +proc set_device_offset*(surface: PSurface, x_offset, y_offset: float64){. cdecl, importc: "cairo_surface_set_device_offset", dynlib: LIB_CAIRO.} -proc surface_get_device_offset*(surface: PSurface, +proc get_device_offset*(surface: PSurface, x_offset, y_offset: var float64){.cdecl, importc: "cairo_surface_get_device_offset", dynlib: LIB_CAIRO.} -proc surface_set_fallback_resolution*(surface: PSurface, x_pixels_per_inch, +proc set_fallback_resolution*(surface: PSurface, x_pixels_per_inch, y_pixels_per_inch: float64){.cdecl, importc: "cairo_surface_set_fallback_resolution", dynlib: LIB_CAIRO.} #* Image-surface functions proc image_surface_create*(format: TFormat, width, height: int32): PSurface{. cdecl, importc: "cairo_image_surface_create", dynlib: LIB_CAIRO.} -proc image_surface_create_for_data*(data: Pbyte, format: TFormat, - width, height, stride: int32): PSurface{. +proc image_surface_create*(data: Pbyte, format: TFormat, + width, height, stride: int32): PSurface{. cdecl, importc: "cairo_image_surface_create_for_data", dynlib: LIB_CAIRO.} -proc image_surface_get_data*(surface: PSurface): cstring{.cdecl, +proc get_data*(surface: PSurface): cstring{.cdecl, importc: "cairo_image_surface_get_data", dynlib: LIB_CAIRO.} -proc image_surface_get_format*(surface: PSurface): TFormat{.cdecl, +proc get_format*(surface: PSurface): TFormat{.cdecl, importc: "cairo_image_surface_get_format", dynlib: LIB_CAIRO.} -proc image_surface_get_width*(surface: PSurface): int32{.cdecl, +proc get_width*(surface: PSurface): int32{.cdecl, importc: "cairo_image_surface_get_width", dynlib: LIB_CAIRO.} -proc image_surface_get_height*(surface: PSurface): int32{.cdecl, +proc get_height*(surface: PSurface): int32{.cdecl, importc: "cairo_image_surface_get_height", dynlib: LIB_CAIRO.} -proc image_surface_get_stride*(surface: PSurface): int32{.cdecl, +proc get_stride*(surface: PSurface): int32{.cdecl, importc: "cairo_image_surface_get_stride", dynlib: LIB_CAIRO.} proc image_surface_create_from_png*(filename: cstring): PSurface{.cdecl, importc: "cairo_image_surface_create_from_png", dynlib: LIB_CAIRO.} -proc image_surface_create_from_png_stream*(read_func: TReadFunc, +proc image_surface_create_from_png*(read_func: TReadFunc, closure: pointer): PSurface{.cdecl, importc: "cairo_image_surface_create_from_png_stream", dynlib: LIB_CAIRO.} #* Pattern creation functions @@ -567,77 +594,79 @@ proc pattern_create_linear*(x0, y0, x1, y1: float64): PPattern{.cdecl, importc: "cairo_pattern_create_linear", dynlib: LIB_CAIRO.} proc pattern_create_radial*(cx0, cy0, radius0, cx1, cy1, radius1: float64): PPattern{. cdecl, importc: "cairo_pattern_create_radial", dynlib: LIB_CAIRO.} -proc pattern_reference*(pattern: PPattern): PPattern{.cdecl, +proc reference*(pattern: PPattern): PPattern{.cdecl, importc: "cairo_pattern_reference", dynlib: LIB_CAIRO.} -proc pattern_destroy*(pattern: PPattern){.cdecl, +proc destroy*(pattern: PPattern){.cdecl, importc: "cairo_pattern_destroy", dynlib: LIB_CAIRO.} -proc pattern_get_reference_count*(pattern: PPattern): int32{.cdecl, +proc get_reference_count*(pattern: PPattern): int32{.cdecl, importc: "cairo_pattern_get_reference_count", dynlib: LIB_CAIRO.} -proc pattern_status*(pattern: PPattern): TStatus{.cdecl, +proc status*(pattern: PPattern): TStatus{.cdecl, importc: "cairo_pattern_status", dynlib: LIB_CAIRO.} -proc pattern_get_user_data*(pattern: PPattern, key: PUserDataKey): Pointer{. +proc get_user_data*(pattern: PPattern, key: PUserDataKey): Pointer{. cdecl, importc: "cairo_pattern_get_user_data", dynlib: LIB_CAIRO.} -proc pattern_set_user_data*(pattern: PPattern, key: PUserDataKey, - user_data: Pointer, destroy: TDestroyFunc): TStatus{. +proc set_user_data*(pattern: PPattern, key: PUserDataKey, + user_data: Pointer, destroy: TDestroyFunc): TStatus{. cdecl, importc: "cairo_pattern_set_user_data", dynlib: LIB_CAIRO.} -proc pattern_get_type*(pattern: PPattern): TPatternType{.cdecl, +proc get_type*(pattern: PPattern): TPatternType{.cdecl, importc: "cairo_pattern_get_type", dynlib: LIB_CAIRO.} -proc pattern_add_color_stop_rgb*(pattern: PPattern, +proc add_color_stop_rgb*(pattern: PPattern, offset, red, green, blue: float64){.cdecl, importc: "cairo_pattern_add_color_stop_rgb", dynlib: LIB_CAIRO.} -proc pattern_add_color_stop_rgba*(pattern: PPattern, +proc add_color_stop_rgba*(pattern: PPattern, offset, red, green, blue, alpha: float64){. cdecl, importc: "cairo_pattern_add_color_stop_rgba", dynlib: LIB_CAIRO.} -proc pattern_set_matrix*(pattern: PPattern, matrix: PMatrix){.cdecl, +proc set_matrix*(pattern: PPattern, matrix: PMatrix){.cdecl, importc: "cairo_pattern_set_matrix", dynlib: LIB_CAIRO.} -proc pattern_get_matrix*(pattern: PPattern, matrix: PMatrix){.cdecl, +proc get_matrix*(pattern: PPattern, matrix: PMatrix){.cdecl, importc: "cairo_pattern_get_matrix", dynlib: LIB_CAIRO.} -proc pattern_set_extend*(pattern: PPattern, extend: TExtend){.cdecl, +proc set_extend*(pattern: PPattern, extend: TExtend){.cdecl, importc: "cairo_pattern_set_extend", dynlib: LIB_CAIRO.} -proc pattern_get_extend*(pattern: PPattern): TExtend{.cdecl, +proc get_extend*(pattern: PPattern): TExtend{.cdecl, importc: "cairo_pattern_get_extend", dynlib: LIB_CAIRO.} -proc pattern_set_filter*(pattern: PPattern, filter: TFilter){.cdecl, +proc set_filter*(pattern: PPattern, filter: TFilter){.cdecl, importc: "cairo_pattern_set_filter", dynlib: LIB_CAIRO.} -proc pattern_get_filter*(pattern: PPattern): TFilter{.cdecl, +proc get_filter*(pattern: PPattern): TFilter{.cdecl, importc: "cairo_pattern_get_filter", dynlib: LIB_CAIRO.} -proc pattern_get_rgba*(pattern: PPattern, red, green, blue, alpha: var float64): TStatus{. +proc get_rgba*(pattern: PPattern, + red, green, blue, alpha: var float64): TStatus{. cdecl, importc: "cairo_pattern_get_rgba", dynlib: LIB_CAIRO.} -proc pattern_get_surface*(pattern: PPattern, surface: PPCairoSurface): TStatus{. +proc get_surface*(pattern: PPattern, surface: PPSurface): TStatus{. cdecl, importc: "cairo_pattern_get_surface", dynlib: LIB_CAIRO.} -proc pattern_get_color_stop_rgba*(pattern: PPattern, index: int32, - offset, red, green, blue, alpha: var float64): TStatus{. +proc get_color_stop_rgba*(pattern: PPattern, index: int32, + offset, red, green, blue, alpha: var float64): TStatus{. cdecl, importc: "cairo_pattern_get_color_stop_rgba", dynlib: LIB_CAIRO.} -proc pattern_get_color_stop_count*(pattern: PPattern, count: var int32): TStatus{. +proc get_color_stop_count*(pattern: PPattern, count: var int32): TStatus{. cdecl, importc: "cairo_pattern_get_color_stop_count", dynlib: LIB_CAIRO.} -proc pattern_get_linear_points*(pattern: PPattern, x0, y0, x1, y1: var float64): TStatus{. +proc get_linear_points*(pattern: PPattern, + x0, y0, x1, y1: var float64): TStatus{. cdecl, importc: "cairo_pattern_get_linear_points", dynlib: LIB_CAIRO.} -proc pattern_get_radial_circles*(pattern: PPattern, - x0, y0, r0, x1, y1, r1: var float64): TStatus{. +proc get_radial_circles*(pattern: PPattern, + x0, y0, r0, x1, y1, r1: var float64): TStatus{. cdecl, importc: "cairo_pattern_get_radial_circles", dynlib: LIB_CAIRO.} #* Matrix functions -proc matrix_init*(matrix: PMatrix, xx, yx, xy, yy, x0, y0: float64){.cdecl, +proc init*(matrix: PMatrix, xx, yx, xy, yy, x0, y0: float64){.cdecl, importc: "cairo_matrix_init", dynlib: LIB_CAIRO.} -proc matrix_init_identity*(matrix: PMatrix){.cdecl, +proc init_identity*(matrix: PMatrix){.cdecl, importc: "cairo_matrix_init_identity", dynlib: LIB_CAIRO.} -proc matrix_init_translate*(matrix: PMatrix, tx, ty: float64){.cdecl, +proc init_translate*(matrix: PMatrix, tx, ty: float64){.cdecl, importc: "cairo_matrix_init_translate", dynlib: LIB_CAIRO.} -proc matrix_init_scale*(matrix: PMatrix, sx, sy: float64){.cdecl, +proc init_scale*(matrix: PMatrix, sx, sy: float64){.cdecl, importc: "cairo_matrix_init_scale", dynlib: LIB_CAIRO.} -proc matrix_init_rotate*(matrix: PMatrix, radians: float64){.cdecl, +proc init_rotate*(matrix: PMatrix, radians: float64){.cdecl, importc: "cairo_matrix_init_rotate", dynlib: LIB_CAIRO.} -proc matrix_translate*(matrix: PMatrix, tx, ty: float64){.cdecl, +proc translate*(matrix: PMatrix, tx, ty: float64){.cdecl, importc: "cairo_matrix_translate", dynlib: LIB_CAIRO.} -proc matrix_scale*(matrix: PMatrix, sx, sy: float64){.cdecl, +proc scale*(matrix: PMatrix, sx, sy: float64){.cdecl, importc: "cairo_matrix_scale", dynlib: LIB_CAIRO.} -proc matrix_rotate*(matrix: PMatrix, radians: float64){.cdecl, +proc rotate*(matrix: PMatrix, radians: float64){.cdecl, importc: "cairo_matrix_rotate", dynlib: LIB_CAIRO.} -proc matrix_invert*(matrix: PMatrix): TStatus{.cdecl, +proc invert*(matrix: PMatrix): TStatus{.cdecl, importc: "cairo_matrix_invert", dynlib: LIB_CAIRO.} -proc matrix_multiply*(result, a, b: PMatrix){.cdecl, +proc multiply*(result, a, b: PMatrix){.cdecl, importc: "cairo_matrix_multiply", dynlib: LIB_CAIRO.} -proc matrix_transform_distance*(matrix: PMatrix, dx, dy: var float64){.cdecl, +proc transform_distance*(matrix: PMatrix, dx, dy: var float64){.cdecl, importc: "cairo_matrix_transform_distance", dynlib: LIB_CAIRO.} -proc matrix_transform_point*(matrix: PMatrix, x, y: var float64){.cdecl, +proc transform_point*(matrix: PMatrix, x, y: var float64){.cdecl, importc: "cairo_matrix_transform_point", dynlib: LIB_CAIRO.} #* PDF functions proc pdf_surface_create*(filename: cstring, @@ -691,3 +720,18 @@ proc version(major, minor, micro: var int32) = major = version div 10000'i32 minor = (version mod (major * 10000'i32)) div 100'i32 micro = (version mod ((major * 10000'i32) + (minor * 100'i32))) + +proc checkStatus*(s: cairo.TStatus) {.noinline.} = + ## if ``s != StatusSuccess`` the error is turned into an appropirate Nimrod + ## exception and raised. + case s + of StatusSuccess: nil + of StatusNoMemory: + raise newException(EOutOfMemory, $statusToString(s))) + of STATUS_READ_ERROR, STATUS_WRITE_ERROR, STATUS_FILE_NOT_FOUND, + STATUS_TEMP_FILE_ERROR: + raise newException(EIO, $statusToString(s)) + else: + raise newException(EAssertion, $statusToString(s)) + + diff --git a/lib/devel/graphics.nim b/lib/pure/colors.nim index 347d16a30..548f07381 100644 --- a/lib/devel/graphics.nim +++ b/lib/pure/colors.nim @@ -1,5 +1,4 @@ # -# # Nimrod's Runtime Library # (c) Copyright 2010 Andreas Rumpf # @@ -10,19 +9,7 @@ ## This module implements graphical output for Nimrod; the current ## implementation uses Cairo under the surface. -import cairo - type - PSurface* = ref TSurface - TSurface {.pure, final.} = object - c: cairo.PSurface - - ... # internal data - - - TRect* = tuple[x, y, width, height: int] - TPoint* = tuple[x, y: int] - TColor* = distinct int ## a color stored as RGB proc `==` *(a, b: TColor): bool {.borrow.} @@ -72,14 +59,14 @@ template mix*(a, b: TColor, fn: expr): expr = template `><` (x: expr): expr = # keep it in the range 0..255 block: - var xx = x # eval only once - if xx >% 255: - xx = if xx < 0: 0 else: 255 - xx + var y = x # eval only once + if y >% 255: + y = if y < 0: 0 else: 255 + y - extract(a, ar, ag, ab) - extract(b, br, bg, bb) - rawRGB(><fn(ar, br), ><fn(ag, bg), ><fn(ab, bb)) + bind extract(a, ar, ag, ab) + bind extract(b, br, bg, bb) + bind rawRGB(><fn(ar, br), ><fn(ag, bg), ><fn(ab, bb)) const @@ -369,44 +356,40 @@ const proc `$`*(c: TColor): string = ## converts a color into its textual representation. Example: ``#00FF00``. result = '#' & toHex(int(c), 6) - -proc newSurface*(width, height: int): PSurface + +proc binaryStrSearch(x: openarray[tuple[name: string, col: TColor]], + y: string): int = + var a = 0 + var b = len(x) - 1 + while a <= b: + var mid = (a + b) div 2 + var c = cmp(x[mid].name, y) + if c < 0: a = mid + 1 + elif c > 0: b = mid - 1 + else: return mid + result = - 1 proc parseColor*(name: string): TColor = - ## parses `s` to a color value. If no valid color could be + ## parses `name` to a color value. If no valid color could be ## parsed ``EInvalidValue`` is raised. - if name[0] == '#' - + if name[0] == '#': + result = TColor(parseHex(name)) + else: + var idx = binaryStrSearch(colorNames, name) + if idx < 0: raise newException(EInvalidValue, "unkown color: " & name) + result = colorNames[idx][1] -proc isColor*(name: string): bool +proc isColor*(name: string): bool = + ## returns true if `name` is a known color name or a hexadecimal color + ## prefixed with ``#``. + if name[0] == '#': + for i in 1 .. name.len-1: + if name[i] notin {'0'..'9', 'a'..'f', 'A'..'F'}: return false + result = true + else: + result = binaryStrSearch(colorNames, name) >= 0 proc rgb*(r, g, b: range[0..255]): TColor = ## constructs a color from RGB values. result = rawRGB(r, g, b) -proc drawRect*(sur: PSurface, r: TRect, col: TColor) -proc fillRect*(sur: PSurface, r: TRect, col: TColor) - -proc drawCircle*(sur: PSurface, mid: TPoint, radius: int) -proc drawCircle*(sur: PSurface, r: TRect) - -proc fillCircle*(sur: PSurface, mid: TPoint, radius: int) -proc fillCircle*(sur: PSurface, r: TRect) - -proc drawElipse*(sur: PSurface, r: TRect) -proc fillElipse*(sur: PSurface, r: TRect) - - -proc textBounds*(text: string): tuple[len, height: int] -proc drawText*(sur: PSurface, p: TPoint, text: string) - -proc drawLine*(sur: PSurface, a, b: TPoint) - -proc `[]`*(sur: PSurface, p: TPoint): TColor -proc `[,]`*(sur: PSurface, x, y: int): TColor -proc `[]=`*(sur: PSurface, p: TPoint, col: TColor) -proc `[,]=`*(sur: PSurface, x, y: int, col: TColor) - -proc writeToPNG*(sur: PSurface, filename: string) - - diff --git a/lib/windows/winlean.nim b/lib/windows/winlean.nim index 9a74a242a..10915272f 100644 --- a/lib/windows/winlean.nim +++ b/lib/windows/winlean.nim @@ -189,6 +189,9 @@ proc GetCommandLineA*(): CString {.importc, stdcall, dynlib: "kernel32".} proc rdFileTime*(f: FILETIME): int64 = result = ze64(f.dwLowDateTime) or (ze64(f.dwHighDateTime) shl 32) +proc rdFileSize*(f: TWin32FindData): int64 = + result = ze64(f.nFileSizeLow) or (ze64(f.nFileSizeHigh) shl 32) + proc Sleep*(dwMilliseconds: int32){.stdcall, dynlib: "kernel32", importc: "Sleep".} diff --git a/tools/nimrepl.nim b/tools/nimrepl.nim index 6e4e3faaa..696052665 100644 --- a/tools/nimrepl.nim +++ b/tools/nimrepl.nim @@ -1,4 +1,4 @@ -import glib2, gtk2, gdk2, osproc, dialogs +import glib2, gtk2, gdk2, osproc, dialogs, strutils type output = tuple[compiler, app: string] @@ -55,17 +55,19 @@ proc FileSaveClicked(menuitem: PGtkMenuItem, userdata: pgpointer) = proc inputKeyPressed(widget: PGtkWidget, event: PGdkEventKey, userdata: pgpointer): bool = - if event.keyval == 65505: + if ($gdk_keyval_name(event.keyval)).tolower() == "shift_l": # SHIFT is pressed shiftPressed = True return False proc inputKeyReleased(widget: PGtkWidget, event: PGdkEventKey, userdata: pgpointer): bool = - if event.keyval == 65505: + echo(gdk_keyval_name(event.keyval)) + if ($gdk_keyval_name(event.keyval)).tolower() == "shift_l": # SHIFT is released shiftPressed = False - if event.keyval == 65293: + if ($gdk_keyval_name(event.keyval)).tolower() == "return": + echo($gdk_keyval_name(event.keyval), "Shift_L") # Enter pressed if shiftPressed == False: var startIter: TGtkTextIter @@ -157,4 +159,4 @@ proc initControls() = gtk_nimrod_init() initControls() -gtk_main() \ No newline at end of file +gtk_main() diff --git a/web/news.txt b/web/news.txt index 84daa490e..4764bc49a 100644 --- a/web/news.txt +++ b/web/news.txt @@ -20,6 +20,7 @@ Bugfixes zeros. - Fixed a bug in ``os.setFilePermissions`` for Windows. - An overloadable symbol can now have the same name as an imported module. +- Fixed a serious bug in ``strutils.cmpIgnoreCase``. Additions |