Я управление версиями создать сценарий, и я использую svn тег версии в нем. Затем каждый раз, когда я получаю версию, которая будет используемой, я создаю сценарий в dbpatches/каталоге, названном как версия для прокрутки до. Задание того сценария должно изменить текущую базу данных, не уничтожая данные. dbpatches/, например, мог бы иметь файлы, названные 201, 220, и 240. Если база данных в настоящее время на уровне 201, примените патч 220, то исправьте 240.
DROP TABLE IF EXISTS `meta`;
CREATE TABLE `meta` (
`property` varchar(255),
`value` varchar(255),
PRIMARY KEY (`property`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
INSERT INTO `meta` VALUES ('version', '$Rev: 240 не забывают тестировать Ваш код прежде, чем считать патч хорошим. Принцип "качество на риск покупателя"!
);
не забывают тестировать Ваш код прежде, чем считать патч хорошим. Принцип "качество на риск покупателя"!
Серьезно:
system( "rm -rf /path/to/directory" )
Возможно, больше того, что вы ищем, но специфичны для unix:
/* Implement system( "rm -rf" ) */
#include <stdlib.h>
#include <unistd.h>
#include <stdio.h>
#include <sys/syslimits.h>
#include <ftw.h>
/* Call unlink or rmdir on the path, as appropriate. */
int
rm( const char *path, const struct stat *s, int flag, struct FTW *f )
{
int status;
int (*rm_func)( const char * );
switch( flag ) {
default: rm_func = unlink; break;
case FTW_DP: rm_func = rmdir;
}
if( status = rm_func( path ), status != 0 )
perror( path );
else
puts( path );
return status;
}
int
main( int argc, char **argv )
{
while( *++argv ) {
if( nftw( *argv, rm, OPEN_MAX, FTW_DEPTH )) {
perror( *argv );
return EXIT_FAILURE;
}
}
return EXIT_SUCCESS;
}
Вы можете использовать boost :: remove_all
из Boost.Filesystem .
Стандартный C ++ не предоставляет для этого никаких средств - вам придется использовать код, специфичный для операционной системы, или кросс-платформенную библиотеку, такую как Boost.