Author: gd Date: 2004-08-20 20:07:17 +0000 (Fri, 20 Aug 2004) New Revision: 1965
WebSVN: http://websvn.samba.org/websvn/changeset.php?rep=samba&path=/&rev=1965&nolog=1 Log: add cli_setattrE (inspired by samba4-code). needed for further migration-work. could someone possibly double-check the byte-count? Guenther Modified: branches/SAMBA_3_0/source/libsmb/clifile.c trunk/source/libsmb/clifile.c Changeset: Modified: branches/SAMBA_3_0/source/libsmb/clifile.c =================================================================== --- branches/SAMBA_3_0/source/libsmb/clifile.c 2004-08-20 15:54:54 UTC (rev 1964) +++ branches/SAMBA_3_0/source/libsmb/clifile.c 2004-08-20 20:07:17 UTC (rev 1965) @@ -983,6 +983,47 @@ } /**************************************************************************** + Do a SMBsetattrE call. +****************************************************************************/ + +BOOL cli_setattrE(struct cli_state *cli, int fd, + time_t c_time, time_t a_time, time_t m_time) + +{ + char *p; + + memset(cli->outbuf,'\0',smb_size); + memset(cli->inbuf,'\0',smb_size); + + set_message(cli->outbuf,7,0,True); + + SCVAL(cli->outbuf,smb_com,SMBsetattrE); + SSVAL(cli->outbuf,smb_tid,cli->cnum); + cli_setup_packet(cli); + + SSVAL(cli->outbuf,smb_vwv0, fd); + put_dos_date3(cli->outbuf,smb_vwv1, c_time); + put_dos_date3(cli->outbuf,smb_vwv3, a_time); + put_dos_date3(cli->outbuf,smb_vwv5, m_time); + + p = smb_buf(cli->outbuf); + *p++ = 4; + + cli_setup_bcc(cli, p); + + cli_send_smb(cli); + if (!cli_receive_smb(cli)) { + return False; + } + + if (cli_is_error(cli)) { + return False; + } + + return True; +} + +/**************************************************************************** Do a SMBsetatr call. ****************************************************************************/ Modified: trunk/source/libsmb/clifile.c =================================================================== --- trunk/source/libsmb/clifile.c 2004-08-20 15:54:54 UTC (rev 1964) +++ trunk/source/libsmb/clifile.c 2004-08-20 20:07:17 UTC (rev 1965) @@ -983,6 +983,47 @@ } /**************************************************************************** + Do a SMBsetattrE call. +****************************************************************************/ + +BOOL cli_setattrE(struct cli_state *cli, int fd, + time_t c_time, time_t a_time, time_t m_time) + +{ + char *p; + + memset(cli->outbuf,'\0',smb_size); + memset(cli->inbuf,'\0',smb_size); + + set_message(cli->outbuf,7,0,True); + + SCVAL(cli->outbuf,smb_com,SMBsetattrE); + SSVAL(cli->outbuf,smb_tid,cli->cnum); + cli_setup_packet(cli); + + SSVAL(cli->outbuf,smb_vwv0, fd); + put_dos_date3(cli->outbuf,smb_vwv1, c_time); + put_dos_date3(cli->outbuf,smb_vwv3, a_time); + put_dos_date3(cli->outbuf,smb_vwv5, m_time); + + p = smb_buf(cli->outbuf); + *p++ = 4; + + cli_setup_bcc(cli, p); + + cli_send_smb(cli); + if (!cli_receive_smb(cli)) { + return False; + } + + if (cli_is_error(cli)) { + return False; + } + + return True; +} + +/**************************************************************************** Do a SMBsetatr call. ****************************************************************************/
