_chmod
, _wchmod
Altera as configurações de permissão de arquivo.
Sintaxe
int _chmod( const char *filename, int pmode );
int _wchmod( const wchar_t *filename, int pmode );
Parâmetros
filename
Nome do arquivo existente.
pmode
Configuração de permissão para o arquivo.
Valor retornado
Essas funções retornarão 0 se a configuração de permissão for alterada com êxito. Um valor retornado de -1 indica uma falha. Se o arquivo especificado não puder ser encontrado, errno
é definido como ENOENT
; se um parâmetro for inválido, errno
é definido como EINVAL
.
Comentários
A _chmod
função altera a configuração de permissão do arquivo especificado por filename
. A configuração de permissão controla o acesso de leitura e gravação para o arquivo. A expressão de inteiro pmode
contém uma ou ambas as seguintes constantes de manifesto, definidas em SYS\Stat.h.
pmode |
Significado |
---|---|
_S_IREAD |
Somente a leitura é permitida. |
_S_IWRITE |
Gravação permitida. (Na verdade, permite leitura e gravação.) |
_S_IREAD | _S_IWRITE |
Leitura e gravação permitidas. |
Quando as duas constantes são informadas, elas são associadas com o operador OR bit a bit (|
). Se a permissão de gravação não for concedida, o arquivo será somente leitura. Observe que todos os arquivos são sempre legíveis; não é possível dar permissão somente gravação. Portanto, os modos _S_IWRITE
e _S_IREAD | _S_IWRITE
são equivalentes.
A função _wchmod
é uma versão de caractere largo da função _chmod
; o argumento filename
para _wchmod
é uma cadeia de caracteres larga. Caso contrário, _wchmod
e _chmod
se comportam de forma idêntica.
Essa função valida seus parâmetros. Se pmode
não for uma combinação de uma das constantes de manifesto ou incorporar um conjunto alternativo de constantes, a função simplesmente as ignorará. Se filename
for NULL
, o manipulador de parâmetro inválido será chamado, conforme descrito em Validação de parâmetro. Se a execução puder continuar, errno
será definido como EINVAL
e a função retornará -1.
Por padrão, o estado global dessa função tem como escopo o aplicativo. Para alterar isso, confira Estado global no CRT.
Mapeamentos de rotina de texto genérico
Rotina Tchar.h | _UNICODE e _MBCS não definidos |
_MBCS definido |
_UNICODE definido |
---|---|---|---|
_tchmod |
_chmod |
_chmod |
_wchmod |
Requisitos
Rotina | Cabeçalho necessário | Cabeçalho opcional |
---|---|---|
_chmod |
<io.h> | <sys/types.h>, <sys/stat.h>, <errno.h> |
_wchmod |
<io.h> ou <wchar.h> | <sys/types.h>, <sys/stat.h>, <errno.h> |
Para obter informações sobre compatibilidade, consulte Compatibilidade.
Exemplo
// crt_chmod.c
// This program uses _chmod to
// change the mode of a file to read-only.
// It then attempts to modify the file.
//
#include <sys/types.h>
#include <sys/stat.h>
#include <io.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
// Change the mode and report error or success
void set_mode_and_report(char * filename, int mask)
{
// Check for failure
if( _chmod( filename, mask ) == -1 )
{
// Determine cause of failure and report.
switch (errno)
{
case EINVAL:
fprintf( stderr, "Invalid parameter to chmod.\n");
break;
case ENOENT:
fprintf( stderr, "File %s not found\n", filename );
break;
default:
// Should never be reached
fprintf( stderr, "Unexpected error in chmod.\n" );
}
}
else
{
if (mask == _S_IREAD)
printf( "Mode set to read-only\n" );
else if (mask & _S_IWRITE)
printf( "Mode set to read/write\n" );
}
fflush(stderr);
}
int main( void )
{
// Create or append to a file.
system( "echo /* End of file */ >> crt_chmod.c_input" );
// Set file mode to read-only:
set_mode_and_report("crt_chmod.c_input ", _S_IREAD );
system( "echo /* End of file */ >> crt_chmod.c_input " );
// Change back to read/write:
set_mode_and_report("crt_chmod.c_input ", _S_IWRITE );
system( "echo /* End of file */ >> crt_chmod.c_input " );
}
A line of text.
A line of text.Mode set to read-only
Access is denied.
Mode set to read/write
Confira também
Manipulação de arquivos
_access
, _waccess
_creat
, _wcreat
_fstat
, _fstat32
, _fstat64
, _fstati64
, _fstat32i64
, , _fstat64i32
_open
, _wopen
_stat
, _wstat
funções