mirror of
https://github.com/boostorg/build.git
synced 2026-02-15 13:02:11 +00:00
* bjam; bump to version 3.1.12 * bjam; make it possible to build in MinGW/MSYS shell * bjam; move profile code to debug.h/c to make it available for use everywhere * bjam; cache all filesystem query operations, Unix and Windows only, include PWD and scanning * bjam; add memory profile info, and sprinkle throught code * bbv2; rewrite some while() loops into for() loops to reduce time and memory * bbv2; keep a single instance counter instead of one per type to reduce memory use * bjam+bbv2; change NORMALIZE_PATH builtin to join path parts to reduce memory use [SVN r31177]
112 lines
2.3 KiB
C
112 lines
2.3 KiB
C
/*
|
|
* Copyright 1993, 1995 Christopher Seiwald.
|
|
*
|
|
* This file is part of Jam - see jam.c for Copyright information.
|
|
*/
|
|
|
|
/* This file is ALSO:
|
|
* Copyright 2001-2004 David Abrahams.
|
|
* Distributed under the Boost Software License, Version 1.0.
|
|
* (See accompanying file LICENSE_1_0.txt or http://www.boost.org/LICENSE_1_0.txt)
|
|
*/
|
|
|
|
/*
|
|
* command.c - maintain lists of commands
|
|
*/
|
|
|
|
# include "jam.h"
|
|
|
|
# include "lists.h"
|
|
# include "parse.h"
|
|
# include "variable.h"
|
|
# include "rules.h"
|
|
# include "debug.h"
|
|
|
|
# include "command.h"
|
|
# include <limits.h>
|
|
# include <string.h>
|
|
|
|
/*
|
|
* cmd_new() - return a new CMD or 0 if too many args
|
|
*/
|
|
|
|
CMD *
|
|
cmd_new(
|
|
RULE *rule,
|
|
LIST *targets,
|
|
LIST *sources,
|
|
LIST *shell )
|
|
{
|
|
CMD *cmd = (CMD *)malloc( sizeof( CMD ) );
|
|
/* lift line-length limitation entirely when JAMSHELL is just "%" */
|
|
int no_limit = ( shell && !strcmp(shell->string,"%") && !list_next(shell) );
|
|
int max_line = MAXLINE;
|
|
int allocated = -1;
|
|
|
|
if ( DEBUG_PROFILE )
|
|
profile_memory( sizeof( CMD ) );
|
|
|
|
cmd->rule = rule;
|
|
cmd->shell = shell;
|
|
cmd->next = 0;
|
|
|
|
lol_init( &cmd->args );
|
|
lol_add( &cmd->args, targets );
|
|
lol_add( &cmd->args, sources );
|
|
cmd->buf = 0;
|
|
|
|
do
|
|
{
|
|
free(cmd->buf); /* free any buffer from previous iteration */
|
|
|
|
cmd->buf = (char*)malloc(max_line + 1);
|
|
|
|
if ( DEBUG_PROFILE )
|
|
profile_memory( max_line + 1 );
|
|
|
|
if (cmd->buf == 0)
|
|
break;
|
|
|
|
allocated = var_string( rule->actions->command, cmd->buf, max_line, &cmd->args );
|
|
|
|
max_line = max_line * 2;
|
|
}
|
|
while( allocated < 0 && max_line < INT_MAX / 2 );
|
|
|
|
if ( !no_limit )
|
|
{
|
|
/* Bail if the result won't fit in MAXLINE */
|
|
char *s = cmd->buf;
|
|
while ( *s )
|
|
{
|
|
size_t l = strcspn( s, "\n" );
|
|
|
|
if ( l > MAXLINE )
|
|
{
|
|
/* We don't free targets/sources/shell if bailing. */
|
|
cmd_free( cmd );
|
|
return 0;
|
|
}
|
|
|
|
s += l;
|
|
if ( *s )
|
|
++s;
|
|
}
|
|
}
|
|
|
|
return cmd;
|
|
}
|
|
|
|
/*
|
|
* cmd_free() - free a CMD
|
|
*/
|
|
|
|
void
|
|
cmd_free( CMD *cmd )
|
|
{
|
|
lol_free( &cmd->args );
|
|
list_free( cmd->shell );
|
|
free( cmd->buf );
|
|
free( (char *)cmd );
|
|
}
|