Browse Source

modded build.py etc to convert comments in external files

Ron Aaron 5 years ago
parent
commit
cd7c7c555c
6 changed files with 651 additions and 630 deletions
  1. 4 4
      nuklear.h
  2. 28 7
      src/build.py
  3. 1 1
      src/paq.bat
  4. 1 1
      src/paq.sh
  5. 182 182
      src/stb_rect_pack.h
  6. 435 435
      src/stb_truetype.h

+ 4 - 4
nuklear.h

@@ -11294,7 +11294,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 /*            stbtt_GetBakedQuad()                 -- compute quad to draw for a given char */
 /*  */
 /*    Improved 3D API (more shippable): */
-/*                       -- optional, but you really want it */
+/*            #include "stb_rect_pack.h"           -- optional, but you really want it */
 /*            stbtt_PackBegin() */
 /*            stbtt_PackSetOversampling()          -- for improved quality on small fonts */
 /*            stbtt_PackFontRanges()               -- pack and renders */
@@ -11465,7 +11465,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 /*  */
 #if 0
 #define STB_TRUETYPE_IMPLEMENTATION  /*  force following include to generate implementation */
-
+#include "stb_truetype.h"
 
 unsigned char ttf_buffer[1<<20];
 unsigned char temp_bitmap[512*512];
@@ -11514,7 +11514,7 @@ void my_stbtt_print(float x, float y, char *text)
 #if 0
 #include <stdio.h>
 #define STB_TRUETYPE_IMPLEMENTATION  /*  force following include to generate implementation */
-
+#include "stb_truetype.h"
 
 char ttf_buffer[1<<25];
 
@@ -15027,7 +15027,7 @@ typedef int stbrp_coord;
 /*                                                                                 // */
 /*                                                                                 // */
 /*  if you get a compile warning due to these symbols being defined more than      // */
-/*  once, move  before          // */
+/*  once, move #include "stb_rect_pack.h" before #include "stb_truetype.h"         // */
 /*                                                                                 // */
 /* ////////////////////////////////////////////////////////////////////////////////// */
 

+ 28 - 7
src/build.py

@@ -2,12 +2,15 @@
 import fnmatch
 import os.path
 import sys
+import re
 
 def print_help():
     print(
-"""usage: python single_header_packer.py --macro <macro> [--intro <files>] --pub <files> --priv <files> [--outro <files>]
+"""usage: python single_header_packer.py --macro <macro> [--intro <files>] --extern <files> --pub <files> --priv1 <files> --priv2 <files> [--outro <files>]
 
        where <files> can be a comma-separated list of files. e.g. --priv *.c,inc/*.h
+       
+       The 'extern' files are placed between 'priv1' and 'priv2'.
 
        The resulting code is packed as follows:
 
@@ -70,6 +73,9 @@ def omit_includes(str, files):
             str = str.replace("#include <" + fname + ">", "");
     return str
 
+def fix_comments(str):
+    return re.sub(r"//(.*)(\n|$)", "/* \\1 */\\2", str)
+
 # Main start
 # ==========
 
@@ -79,8 +85,9 @@ if len(sys.argv) < 2:
 
 intro_files = []
 pub_files = []
-priv_files = []
-outro_files = []
+priv_files1 = []
+outro_files2 = []
+extern_files = []
 cur_arg = 1
 macro = ""
 
@@ -99,9 +106,15 @@ while cur_arg < len(sys.argv):
     elif sys.argv[cur_arg] == "--pub":
         cur_arg += 1
         pub_files = parse_files(sys.argv[cur_arg])
-    elif sys.argv[cur_arg] == "--priv":
+    elif sys.argv[cur_arg] == "--priv1":
+        cur_arg += 1
+        priv_files1 = parse_files(sys.argv[cur_arg])
+    elif sys.argv[cur_arg] == "--priv2":
         cur_arg += 1
-        priv_files = parse_files(sys.argv[cur_arg])
+        priv_files2 = parse_files(sys.argv[cur_arg])
+    elif sys.argv[cur_arg] == "--extern":
+        cur_arg += 1
+        extern_files = parse_files(sys.argv[cur_arg])
     elif sys.argv[cur_arg] == "--outro":
         cur_arg += 1
         outro_files = parse_files(sys.argv[cur_arg])
@@ -134,9 +147,17 @@ for f in pub_files:
 
 print(os.linesep + "#ifdef " + macro + "_IMPLEMENTATION");
 print("");
-for f in priv_files:
+
+for f in priv_files1:
     print(omit_includes(open(f, 'r').read(),
-                        pub_files + priv_files))
+                        pub_files + priv_files1 + priv_files2 + extern_files))
+for f in extern_files:
+    print(fix_comments(open(f, 'r').read()))
+
+for f in priv_files2:
+    print(omit_includes(open(f, 'r').read(),
+                        pub_files + priv_files1 + priv_files2 + extern_files))
+
 print("#endif /* " + macro + "_IMPLEMENTATION */");
 
 print(os.linesep + "/*")

+ 1 - 1
src/paq.bat

@@ -1 +1 @@
-build.py --macro NK --intro HEADER --pub nuklear.h --priv nuklear_internal.h,nuklear_math.c,nuklear_util.c,nuklear_color.c,nuklear_utf8.c,nuklear_buffer.c,nuklear_string.c,nuklear_draw.c,nuklear_vertex.c,stb_rect_pack.h,stb_truetype.h,nuklear_font.c,nuklear_input.c,nuklear_style.c,nuklear_context.c,nuklear_pool.c,nuklear_page_element.c,nuklear_table.c,nuklear_panel.c,nuklear_window.c,nuklear_popup.c,nuklear_contextual.c,nuklear_menu.c,nuklear_layout.c,nuklear_tree.c,nuklear_group.c,nuklear_list_view.c,nuklear_widget.c,nuklear_text.c,nuklear_image.c,nuklear_button.c,nuklear_toggle.c,nuklear_selectable.c,nuklear_slider.c,nuklear_progress.c,nuklear_scrollbar.c,nuklear_text_editor.c,nuklear_edit.c,nuklear_property.c,nuklear_chart.c,nuklear_color_picker.c,nuklear_combo.c,nuklear_tooltip.c --outro LICENSE,CHANGELOG,CREDITS > ..\nuklear.h
+build.py --macro NK --intro HEADER --pub nuklear.h --priv1 nuklear_internal.h,nuklear_math.c,nuklear_util.c,nuklear_color.c,nuklear_utf8.c,nuklear_buffer.c,nuklear_string.c,nuklear_draw.c,nuklear_vertex.c --extern stb_rect_pack.h,stb_truetype.h --priv2 nuklear_font.c,nuklear_input.c,nuklear_style.c,nuklear_context.c,nuklear_pool.c,nuklear_page_element.c,nuklear_table.c,nuklear_panel.c,nuklear_window.c,nuklear_popup.c,nuklear_contextual.c,nuklear_menu.c,nuklear_layout.c,nuklear_tree.c,nuklear_group.c,nuklear_list_view.c,nuklear_widget.c,nuklear_text.c,nuklear_image.c,nuklear_button.c,nuklear_toggle.c,nuklear_selectable.c,nuklear_slider.c,nuklear_progress.c,nuklear_scrollbar.c,nuklear_text_editor.c,nuklear_edit.c,nuklear_property.c,nuklear_chart.c,nuklear_color_picker.c,nuklear_combo.c,nuklear_tooltip.c --outro LICENSE,CHANGELOG,CREDITS > ..\nuklear.h

+ 1 - 1
src/paq.sh

@@ -1,3 +1,3 @@
 #!/bin/sh
-python build.py --macro NK --intro HEADER --pub nuklear.h --priv nuklear_internal.h,nuklear_math.c,nuklear_util.c,nuklear_color.c,nuklear_utf8.c,nuklear_buffer.c,nuklear_string.c,nuklear_draw.c,nuklear_vertex.c,stb_rect_pack.h,stb_truetype.h,nuklear_font.c,nuklear_input.c,nuklear_style.c,nuklear_context.c,nuklear_pool.c,nuklear_page_element.c,nuklear_table.c,nuklear_panel.c,nuklear_window.c,nuklear_popup.c,nuklear_contextual.c,nuklear_menu.c,nuklear_layout.c,nuklear_tree.c,nuklear_group.c,nuklear_list_view.c,nuklear_widget.c,nuklear_text.c,nuklear_image.c,nuklear_button.c,nuklear_toggle.c,nuklear_selectable.c,nuklear_slider.c,nuklear_progress.c,nuklear_scrollbar.c,nuklear_text_editor.c,nuklear_edit.c,nuklear_property.c,nuklear_chart.c,nuklear_color_picker.c,nuklear_combo.c,nuklear_tooltip.c --outro LICENSE,CHANGELOG,CREDITS
+python build.py --macro NK --intro HEADER --pub nuklear.h --priv1 nuklear_internal.h,nuklear_math.c,nuklear_util.c,nuklear_color.c,nuklear_utf8.c,nuklear_buffer.c,nuklear_string.c,nuklear_draw.c,nuklear_vertex.c --extern stb_rect_pack.h,stb_truetype.h --priv2 nuklear_font.c,nuklear_input.c,nuklear_style.c,nuklear_context.c,nuklear_pool.c,nuklear_page_element.c,nuklear_table.c,nuklear_panel.c,nuklear_window.c,nuklear_popup.c,nuklear_contextual.c,nuklear_menu.c,nuklear_layout.c,nuklear_tree.c,nuklear_group.c,nuklear_list_view.c,nuklear_widget.c,nuklear_text.c,nuklear_image.c,nuklear_button.c,nuklear_toggle.c,nuklear_selectable.c,nuklear_slider.c,nuklear_progress.c,nuklear_scrollbar.c,nuklear_text_editor.c,nuklear_edit.c,nuklear_property.c,nuklear_chart.c,nuklear_color_picker.c,nuklear_combo.c,nuklear_tooltip.c --outro LICENSE,CHANGELOG,CREDITS
 

+ 182 - 182
src/stb_rect_pack.h

@@ -1,60 +1,60 @@
-/*  stb_rect_pack.h - v1.00 - public domain - rectangle packing */
-/*  Sean Barrett 2014 */
-/*  */
-/*  Useful for e.g. packing rectangular textures into an atlas. */
-/*  Does not do rotation. */
-/*  */
-/*  Not necessarily the awesomest packing method, but better than */
-/*  the totally naive one in stb_truetype (which is primarily what */
-/*  this is meant to replace). */
-/*  */
-/*  Has only had a few tests run, may have issues. */
-/*  */
-/*  More docs to come. */
-/*  */
-/*  No memory allocations; uses qsort() and assert() from stdlib. */
-/*  Can override those by defining STBRP_SORT and STBRP_ASSERT. */
-/*  */
-/*  This library currently uses the Skyline Bottom-Left algorithm. */
-/*  */
-/*  Please note: better rectangle packers are welcome! Please */
-/*  implement them to the same API, but with a different init */
-/*  function. */
-/*  */
-/*  Credits */
-/*  */
-/*   Library */
-/*     Sean Barrett */
-/*   Minor features */
-/*     Martins Mozeiko */
-/*     github:IntellectualKitty */
-/*  */
-/*   Bugfixes / warning fixes */
-/*     Jeremy Jaussaud */
-/*     Fabian Giesen */
-/*  */
-/*  Version history: */
-/*  */
-/*      1.00  (2019-02-25)  avoid small space waste; gracefully fail too-wide rectangles */
-/*      0.99  (2019-02-07)  warning fixes */
-/*      0.11  (2017-03-03)  return packing success/fail result */
-/*      0.10  (2016-10-25)  remove cast-away-const to avoid warnings */
-/*      0.09  (2016-08-27)  fix compiler warnings */
-/*      0.08  (2015-09-13)  really fix bug with empty rects (w=0 or h=0) */
-/*      0.07  (2015-09-13)  fix bug with empty rects (w=0 or h=0) */
-/*      0.06  (2015-04-15)  added STBRP_SORT to allow replacing qsort */
-/*      0.05:  added STBRP_ASSERT to allow replacing assert */
-/*      0.04:  fixed minor bug in STBRP_LARGE_RECTS support */
-/*      0.01:  initial release */
-/*  */
-/*  LICENSE */
-/*  */
-/*    See end of file for license information. */
-
-/* //////////////////////////////////////////////////////////////////////////// */
-/*  */
-/*        INCLUDE SECTION */
-/*  */
+// stb_rect_pack.h - v1.00 - public domain - rectangle packing
+// Sean Barrett 2014
+//
+// Useful for e.g. packing rectangular textures into an atlas.
+// Does not do rotation.
+//
+// Not necessarily the awesomest packing method, but better than
+// the totally naive one in stb_truetype (which is primarily what
+// this is meant to replace).
+//
+// Has only had a few tests run, may have issues.
+//
+// More docs to come.
+//
+// No memory allocations; uses qsort() and assert() from stdlib.
+// Can override those by defining STBRP_SORT and STBRP_ASSERT.
+//
+// This library currently uses the Skyline Bottom-Left algorithm.
+//
+// Please note: better rectangle packers are welcome! Please
+// implement them to the same API, but with a different init
+// function.
+//
+// Credits
+//
+//  Library
+//    Sean Barrett
+//  Minor features
+//    Martins Mozeiko
+//    github:IntellectualKitty
+//
+//  Bugfixes / warning fixes
+//    Jeremy Jaussaud
+//    Fabian Giesen
+//
+// Version history:
+//
+//     1.00  (2019-02-25)  avoid small space waste; gracefully fail too-wide rectangles
+//     0.99  (2019-02-07)  warning fixes
+//     0.11  (2017-03-03)  return packing success/fail result
+//     0.10  (2016-10-25)  remove cast-away-const to avoid warnings
+//     0.09  (2016-08-27)  fix compiler warnings
+//     0.08  (2015-09-13)  really fix bug with empty rects (w=0 or h=0)
+//     0.07  (2015-09-13)  fix bug with empty rects (w=0 or h=0)
+//     0.06  (2015-04-15)  added STBRP_SORT to allow replacing qsort
+//     0.05:  added STBRP_ASSERT to allow replacing assert
+//     0.04:  fixed minor bug in STBRP_LARGE_RECTS support
+//     0.01:  initial release
+//
+// LICENSE
+//
+//   See end of file for license information.
+
+//////////////////////////////////////////////////////////////////////////////
+//
+//       INCLUDE SECTION
+//
 
 #ifndef STB_INCLUDE_STB_RECT_PACK_H
 #define STB_INCLUDE_STB_RECT_PACK_H
@@ -82,76 +82,76 @@ typedef unsigned short stbrp_coord;
 #endif
 
 STBRP_DEF int stbrp_pack_rects (stbrp_context *context, stbrp_rect *rects, int num_rects);
-/*  Assign packed locations to rectangles. The rectangles are of type */
-/*  'stbrp_rect' defined below, stored in the array 'rects', and there */
-/*  are 'num_rects' many of them. */
-/*  */
-/*  Rectangles which are successfully packed have the 'was_packed' flag */
-/*  set to a non-zero value and 'x' and 'y' store the minimum location */
-/*  on each axis (i.e. bottom-left in cartesian coordinates, top-left */
-/*  if you imagine y increasing downwards). Rectangles which do not fit */
-/*  have the 'was_packed' flag set to 0. */
-/*  */
-/*  You should not try to access the 'rects' array from another thread */
-/*  while this function is running, as the function temporarily reorders */
-/*  the array while it executes. */
-/*  */
-/*  To pack into another rectangle, you need to call stbrp_init_target */
-/*  again. To continue packing into the same rectangle, you can call */
-/*  this function again. Calling this multiple times with multiple rect */
-/*  arrays will probably produce worse packing results than calling it */
-/*  a single time with the full rectangle array, but the option is */
-/*  available. */
-/*  */
-/*  The function returns 1 if all of the rectangles were successfully */
-/*  packed and 0 otherwise. */
+// Assign packed locations to rectangles. The rectangles are of type
+// 'stbrp_rect' defined below, stored in the array 'rects', and there
+// are 'num_rects' many of them.
+//
+// Rectangles which are successfully packed have the 'was_packed' flag
+// set to a non-zero value and 'x' and 'y' store the minimum location
+// on each axis (i.e. bottom-left in cartesian coordinates, top-left
+// if you imagine y increasing downwards). Rectangles which do not fit
+// have the 'was_packed' flag set to 0.
+//
+// You should not try to access the 'rects' array from another thread
+// while this function is running, as the function temporarily reorders
+// the array while it executes.
+//
+// To pack into another rectangle, you need to call stbrp_init_target
+// again. To continue packing into the same rectangle, you can call
+// this function again. Calling this multiple times with multiple rect
+// arrays will probably produce worse packing results than calling it
+// a single time with the full rectangle array, but the option is
+// available.
+//
+// The function returns 1 if all of the rectangles were successfully
+// packed and 0 otherwise.
 
 struct stbrp_rect
 {
-   /*  reserved for your use: */
+   // reserved for your use:
    int            id;
 
-   /*  input: */
+   // input:
    stbrp_coord    w, h;
 
-   /*  output: */
+   // output:
    stbrp_coord    x, y;
-   int            was_packed;  /*  non-zero if valid packing */
+   int            was_packed;  // non-zero if valid packing
 
-}; /*  16 bytes, nominally */
+}; // 16 bytes, nominally
 
 
 STBRP_DEF void stbrp_init_target (stbrp_context *context, int width, int height, stbrp_node *nodes, int num_nodes);
-/*  Initialize a rectangle packer to: */
-/*     pack a rectangle that is 'width' by 'height' in dimensions */
-/*     using temporary storage provided by the array 'nodes', which is 'num_nodes' long */
-/*  */
-/*  You must call this function every time you start packing into a new target. */
-/*  */
-/*  There is no "shutdown" function. The 'nodes' memory must stay valid for */
-/*  the following stbrp_pack_rects() call (or calls), but can be freed after */
-/*  the call (or calls) finish. */
-/*  */
-/*  Note: to guarantee best results, either: */
-/*        1. make sure 'num_nodes' >= 'width' */
-/*    or  2. call stbrp_allow_out_of_mem() defined below with 'allow_out_of_mem = 1' */
-/*  */
-/*  If you don't do either of the above things, widths will be quantized to multiples */
-/*  of small integers to guarantee the algorithm doesn't run out of temporary storage. */
-/*  */
-/*  If you do #2, then the non-quantized algorithm will be used, but the algorithm */
-/*  may run out of temporary storage and be unable to pack some rectangles. */
+// Initialize a rectangle packer to:
+//    pack a rectangle that is 'width' by 'height' in dimensions
+//    using temporary storage provided by the array 'nodes', which is 'num_nodes' long
+//
+// You must call this function every time you start packing into a new target.
+//
+// There is no "shutdown" function. The 'nodes' memory must stay valid for
+// the following stbrp_pack_rects() call (or calls), but can be freed after
+// the call (or calls) finish.
+//
+// Note: to guarantee best results, either:
+//       1. make sure 'num_nodes' >= 'width'
+//   or  2. call stbrp_allow_out_of_mem() defined below with 'allow_out_of_mem = 1'
+//
+// If you don't do either of the above things, widths will be quantized to multiples
+// of small integers to guarantee the algorithm doesn't run out of temporary storage.
+//
+// If you do #2, then the non-quantized algorithm will be used, but the algorithm
+// may run out of temporary storage and be unable to pack some rectangles.
 
 STBRP_DEF void stbrp_setup_allow_out_of_mem (stbrp_context *context, int allow_out_of_mem);
-/*  Optionally call this function after init but before doing any packing to */
-/*  change the handling of the out-of-temp-memory scenario, described above. */
-/*  If you call init again, this will be reset to the default (false). */
+// Optionally call this function after init but before doing any packing to
+// change the handling of the out-of-temp-memory scenario, described above.
+// If you call init again, this will be reset to the default (false).
 
 
 STBRP_DEF void stbrp_setup_heuristic (stbrp_context *context, int heuristic);
-/*  Optionally select which packing heuristic the library should use. Different */
-/*  heuristics will produce better/worse results for different data sets. */
-/*  If you call init again, this will be reset to the default. */
+// Optionally select which packing heuristic the library should use. Different
+// heuristics will produce better/worse results for different data sets.
+// If you call init again, this will be reset to the default.
 
 enum
 {
@@ -161,10 +161,10 @@ enum
 };
 
 
-/* //////////////////////////////////////////////////////////////////////////// */
-/*  */
-/*  the details of the following structures don't matter to you, but they must */
-/*  be visible so you can handle the memory allocations for them */
+//////////////////////////////////////////////////////////////////////////////
+//
+// the details of the following structures don't matter to you, but they must
+// be visible so you can handle the memory allocations for them
 
 struct stbrp_node
 {
@@ -182,7 +182,7 @@ struct stbrp_context
    int num_nodes;
    stbrp_node *active_head;
    stbrp_node *free_head;
-   stbrp_node extra[2]; /*  we allocate two extra nodes so optimal user-node-count is 'width' not 'width+2' */
+   stbrp_node extra[2]; // we allocate two extra nodes so optimal user-node-count is 'width' not 'width+2'
 };
 
 #ifdef __cplusplus
@@ -191,10 +191,10 @@ struct stbrp_context
 
 #endif
 
-/* //////////////////////////////////////////////////////////////////////////// */
-/*  */
-/*      IMPLEMENTATION SECTION */
-/*  */
+//////////////////////////////////////////////////////////////////////////////
+//
+//     IMPLEMENTATION SECTION
+//
 
 #ifdef STB_RECT_PACK_IMPLEMENTATION
 #ifndef STBRP_SORT
@@ -233,18 +233,18 @@ STBRP_DEF void stbrp_setup_heuristic(stbrp_context *context, int heuristic)
 STBRP_DEF void stbrp_setup_allow_out_of_mem(stbrp_context *context, int allow_out_of_mem)
 {
    if (allow_out_of_mem)
-      /*  if it's ok to run out of memory, then don't bother aligning them; */
-      /*  this gives better packing, but may fail due to OOM (even though */
-      /*  the rectangles easily fit). @TODO a smarter approach would be to only */
-      /*  quantize once we've hit OOM, then we could get rid of this parameter. */
+      // if it's ok to run out of memory, then don't bother aligning them;
+      // this gives better packing, but may fail due to OOM (even though
+      // the rectangles easily fit). @TODO a smarter approach would be to only
+      // quantize once we've hit OOM, then we could get rid of this parameter.
       context->align = 1;
    else {
-      /*  if it's not ok to run out of memory, then quantize the widths */
-      /*  so that num_nodes is always enough nodes. */
-      /*  */
-      /*  I.e. num_nodes * align >= width */
-      /*                   align >= width / num_nodes */
-      /*                   align = ceil(width/num_nodes) */
+      // if it's not ok to run out of memory, then quantize the widths
+      // so that num_nodes is always enough nodes.
+      //
+      // I.e. num_nodes * align >= width
+      //                  align >= width / num_nodes
+      //                  align = ceil(width/num_nodes)
 
       context->align = (context->width + context->num_nodes-1) / context->num_nodes;
    }
@@ -269,7 +269,7 @@ STBRP_DEF void stbrp_init_target(stbrp_context *context, int width, int height,
    context->num_nodes = num_nodes;
    stbrp_setup_allow_out_of_mem(context, 0);
 
-   /*  node 0 is the full width, node 1 is the sentinel (lets us not store width explicitly) */
+   // node 0 is the full width, node 1 is the sentinel (lets us not store width explicitly)
    context->extra[0].x = 0;
    context->extra[0].y = 0;
    context->extra[0].next = &context->extra[1];
@@ -282,7 +282,7 @@ STBRP_DEF void stbrp_init_target(stbrp_context *context, int width, int height,
    context->extra[1].next = NULL;
 }
 
-/*  find minimum y position if it starts at x1 */
+// find minimum y position if it starts at x1
 static int stbrp__skyline_find_min_y(stbrp_context *c, stbrp_node *first, int x0, int width, int *pwaste)
 {
    stbrp_node *node = first;
@@ -294,11 +294,11 @@ static int stbrp__skyline_find_min_y(stbrp_context *c, stbrp_node *first, int x0
    STBRP_ASSERT(first->x <= x0);
 
    #if 0
-   /*  skip in case we're past the node */
+   // skip in case we're past the node
    while (node->next->x <= x0)
       ++node;
    #else
-   STBRP_ASSERT(node->next->x > x0); /*  we ended up handling this in the caller for efficiency */
+   STBRP_ASSERT(node->next->x > x0); // we ended up handling this in the caller for efficiency
    #endif
 
    STBRP_ASSERT(node->x <= x0);
@@ -308,18 +308,18 @@ static int stbrp__skyline_find_min_y(stbrp_context *c, stbrp_node *first, int x0
    visited_width = 0;
    while (node->x < x1) {
       if (node->y > min_y) {
-         /*  raise min_y higher. */
-         /*  we've accounted for all waste up to min_y, */
-         /*  but we'll now add more waste for everything we've visted */
+         // raise min_y higher.
+         // we've accounted for all waste up to min_y,
+         // but we'll now add more waste for everything we've visted
          waste_area += visited_width * (node->y - min_y);
          min_y = node->y;
-         /*  the first time through, visited_width might be reduced */
+         // the first time through, visited_width might be reduced
          if (node->x < x0)
             visited_width += node->next->x - x0;
          else
             visited_width += node->next->x - node->x;
       } else {
-         /*  add waste area */
+         // add waste area
          int under_width = node->next->x - node->x;
          if (under_width + visited_width > width)
             under_width = width - visited_width;
@@ -345,12 +345,12 @@ static stbrp__findresult stbrp__skyline_find_best_pos(stbrp_context *c, int widt
    stbrp__findresult fr;
    stbrp_node **prev, *node, *tail, **best = NULL;
 
-   /*  align to multiple of c->align */
+   // align to multiple of c->align
    width = (width + c->align - 1);
    width -= width % c->align;
    STBRP_ASSERT(width % c->align == 0);
 
-   /*  if it can't possibly fit, bail immediately */
+   // if it can't possibly fit, bail immediately
    if (width > c->width || height > c->height) {
       fr.prev_link = NULL;
       fr.x = fr.y = 0;
@@ -362,16 +362,16 @@ static stbrp__findresult stbrp__skyline_find_best_pos(stbrp_context *c, int widt
    while (node->x + width <= c->width) {
       int y,waste;
       y = stbrp__skyline_find_min_y(c, node, node->x, width, &waste);
-      if (c->heuristic == STBRP_HEURISTIC_Skyline_BL_sortHeight) { /*  actually just want to test BL */
-         /*  bottom left */
+      if (c->heuristic == STBRP_HEURISTIC_Skyline_BL_sortHeight) { // actually just want to test BL
+         // bottom left
          if (y < best_y) {
             best_y = y;
             best = prev;
          }
       } else {
-         /*  best-fit */
+         // best-fit
          if (y + height <= c->height) {
-            /*  can only use it if it first vertically */
+            // can only use it if it first vertically
             if (y < best_y || (y == best_y && waste < best_waste)) {
                best_y = y;
                best_waste = waste;
@@ -385,35 +385,35 @@ static stbrp__findresult stbrp__skyline_find_best_pos(stbrp_context *c, int widt
 
    best_x = (best == NULL) ? 0 : (*best)->x;
 
-   /*  if doing best-fit (BF), we also have to try aligning right edge to each node position */
-   /*  */
-   /*  e.g, if fitting */
-   /*  */
-   /*      ____________________ */
-   /*     |____________________| */
-   /*  */
-   /*             into */
-   /*  */
-   /*    |                         | */
-   /*    |             ____________| */
-   /*    |____________| */
-   /*  */
-   /*  then right-aligned reduces waste, but bottom-left BL is always chooses left-aligned */
-   /*  */
-   /*  This makes BF take about 2x the time */
+   // if doing best-fit (BF), we also have to try aligning right edge to each node position
+   //
+   // e.g, if fitting
+   //
+   //     ____________________
+   //    |____________________|
+   //
+   //            into
+   //
+   //   |                         |
+   //   |             ____________|
+   //   |____________|
+   //
+   // then right-aligned reduces waste, but bottom-left BL is always chooses left-aligned
+   //
+   // This makes BF take about 2x the time
 
    if (c->heuristic == STBRP_HEURISTIC_Skyline_BF_sortHeight) {
       tail = c->active_head;
       node = c->active_head;
       prev = &c->active_head;
-      /*  find first node that's admissible */
+      // find first node that's admissible
       while (tail->x < width)
          tail = tail->next;
       while (tail) {
          int xpos = tail->x - width;
          int y,waste;
          STBRP_ASSERT(xpos >= 0);
-         /*  find the left position that matches this */
+         // find the left position that matches this
          while (node->next->x <= xpos) {
             prev = &node->next;
             node = node->next;
@@ -443,33 +443,33 @@ static stbrp__findresult stbrp__skyline_find_best_pos(stbrp_context *c, int widt
 
 static stbrp__findresult stbrp__skyline_pack_rectangle(stbrp_context *context, int width, int height)
 {
-   /*  find best position according to heuristic */
+   // find best position according to heuristic
    stbrp__findresult res = stbrp__skyline_find_best_pos(context, width, height);
    stbrp_node *node, *cur;
 
-   /*  bail if: */
-   /*     1. it failed */
-   /*     2. the best node doesn't fit (we don't always check this) */
-   /*     3. we're out of memory */
+   // bail if:
+   //    1. it failed
+   //    2. the best node doesn't fit (we don't always check this)
+   //    3. we're out of memory
    if (res.prev_link == NULL || res.y + height > context->height || context->free_head == NULL) {
       res.prev_link = NULL;
       return res;
    }
 
-   /*  on success, create new node */
+   // on success, create new node
    node = context->free_head;
    node->x = (stbrp_coord) res.x;
    node->y = (stbrp_coord) (res.y + height);
 
    context->free_head = node->next;
 
-   /*  insert the new node into the right starting point, and */
-   /*  let 'cur' point to the remaining nodes needing to be */
-   /*  stiched back in */
+   // insert the new node into the right starting point, and
+   // let 'cur' point to the remaining nodes needing to be
+   // stiched back in
 
    cur = *res.prev_link;
    if (cur->x < res.x) {
-      /*  preserve the existing one, so start testing with the next one */
+      // preserve the existing one, so start testing with the next one
       stbrp_node *next = cur->next;
       cur->next = node;
       cur = next;
@@ -477,17 +477,17 @@ static stbrp__findresult stbrp__skyline_pack_rectangle(stbrp_context *context, i
       *res.prev_link = node;
    }
 
-   /*  from here, traverse cur and free the nodes, until we get to one */
-   /*  that shouldn't be freed */
+   // from here, traverse cur and free the nodes, until we get to one
+   // that shouldn't be freed
    while (cur->next && cur->next->x <= res.x + width) {
       stbrp_node *next = cur->next;
-      /*  move the current node to the free list */
+      // move the current node to the free list
       cur->next = context->free_head;
       context->free_head = cur;
       cur = next;
    }
 
-   /*  stitch the list back in */
+   // stitch the list back in
    node->next = cur;
 
    if (cur->x < res.x + width)
@@ -548,17 +548,17 @@ STBRP_DEF int stbrp_pack_rects(stbrp_context *context, stbrp_rect *rects, int nu
 {
    int i, all_rects_packed = 1;
 
-   /*  we use the 'was_packed' field internally to allow sorting/unsorting */
+   // we use the 'was_packed' field internally to allow sorting/unsorting
    for (i=0; i < num_rects; ++i) {
       rects[i].was_packed = i;
    }
 
-   /*  sort according to heuristic */
+   // sort according to heuristic
    STBRP_SORT(rects, num_rects, sizeof(rects[0]), rect_height_compare);
 
    for (i=0; i < num_rects; ++i) {
       if (rects[i].w == 0 || rects[i].h == 0) {
-         rects[i].x = rects[i].y = 0;  /*  empty rect needs no space */
+         rects[i].x = rects[i].y = 0;  // empty rect needs no space
       } else {
          stbrp__findresult fr = stbrp__skyline_pack_rectangle(context, rects[i].w, rects[i].h);
          if (fr.prev_link) {
@@ -570,17 +570,17 @@ STBRP_DEF int stbrp_pack_rects(stbrp_context *context, stbrp_rect *rects, int nu
       }
    }
 
-   /*  unsort */
+   // unsort
    STBRP_SORT(rects, num_rects, sizeof(rects[0]), rect_original_order);
 
-   /*  set was_packed flags and all_rects_packed status */
+   // set was_packed flags and all_rects_packed status
    for (i=0; i < num_rects; ++i) {
       rects[i].was_packed = !(rects[i].x == STBRP__MAXVAL && rects[i].y == STBRP__MAXVAL);
       if (!rects[i].was_packed)
          all_rects_packed = 0;
    }
 
-   /*  return the all_rects_packed status */
+   // return the all_rects_packed status
    return all_rects_packed;
 }
 #endif

File diff suppressed because it is too large
+ 435 - 435
src/stb_truetype.h


Some files were not shown because too many files changed in this diff