This function takes a string and an output buffer and a desired width.





This function takes a string and an output buffer and a desired width.
Tags: word wrap
Code Snippet:
/*
This function takes a string and an output buffer and a desired width. It then copies
the string to the buffer, inserting a new line character when a certain line
length is reached. If the end of the line is in the middle of a word, it will
backtrack along the string until white space is found.
*/
#include <string.h>
#include <ctype.h>
char* word_wrap (char* buffer, char* string, int line_width) {
int i = 0;
int k, counter;
while(i < strlen( string ) )
{
// copy string until the end of the line is reached
for ( counter = 1; counter <= line_width; counter++ )
{
// check if end of string reached
if ( i == strlen( string ) )
{
buffer[ i ] = 0;
return buffer;
}
buffer[ i ] = string[ i ];
// check for newlines embedded in the original input
// and reset the index
if ( buffer[ i ] == '\n' )
{
counter = 1;
}
i++;
}
// check for whitespace
if ( isspace( string[ i ] ) )
{
buffer[i] = '\n';
i++;
}
else
{
// check for nearest whitespace back in string
for ( k = i; k > 0; k--)
{
if ( isspace( string[ k ] ) )
{
buffer[ k ] = '\n';
// set string index back to character after this one
i = k + 1;
break;
}
}
}
}
buffer[ i ] = 0;
return buffer; ActionScript - ActionScript 3 - Apache - AppleScript - ASP - Assembler - Bash - C - C# - C++ - ColdFusion - CSS - Delphi - DOS Batch - Fortran - HTML - iPhone - Java - JavaScript - jQuery - Lisp - MatLab - Maxscript - MXML - MySQL - Objective C - Other - Pascal - Perl - PHP - PL SQL - Prolog - Pseudocode - Python - Rails - SmallTalk - Smarty - SML - SPSS - SQL - SVN - Symfony - TCL - VB.NET - Visual Basic - XHTML - XML - XSLT
© 2000-2012 Xentrik.Net
