> -----Original Message----- > From: stef...@apache.org [mailto:stef...@apache.org] > Sent: dinsdag 19 november 2013 23:17 > To: comm...@subversion.apache.org > Subject: svn commit: r1543596 - in /subversion/trunk/subversion: > libsvn_fs_x/changes.c libsvn_fs_x/noderevs.c libsvn_fs_x/reps.c > libsvn_fs_x/string_table.c libsvn_subr/packed_data.c > > Author: stefan2 > Date: Tue Nov 19 22:17:09 2013 > New Revision: 1543596 > > URL: http://svn.apache.org/r1543596 > Log: > Silence a number of integer size conversion warnings by casting the output > of our rather generic reader functions to the correct target type. > > * subversion/libsvn_fs_x/string_table.c > (svn_fs_x__read_string_table): explicitly cast to the target type > * subversion/libsvn_fs_x/reps.c > (svn_fs_x__read_reps_container): ditto > * subversion/libsvn_fs_x/noderevs.c > (svn_fs_x__read_noderes_container): ditto > * subversion/libsvn_fs_x/changes.c > (svn_fs_x__read_changes_container): ditto > * subversion/libsvn_subr/packed_data.c > (svn_packed__get_bytes): ditto > > Modified: > subversion/trunk/subversion/libsvn_fs_x/changes.c > subversion/trunk/subversion/libsvn_fs_x/noderevs.c > subversion/trunk/subversion/libsvn_fs_x/reps.c > subversion/trunk/subversion/libsvn_fs_x/string_table.c > subversion/trunk/subversion/libsvn_subr/packed_data.c > > Modified: subversion/trunk/subversion/libsvn_fs_x/changes.c > URL: > http://svn.apache.org/viewvc/subversion/trunk/subversion/libsvn_fs_x/cha > nges.c?rev=1543596&r1=1543595&r2=1543596&view=diff > ========================================================== > ==================== > --- subversion/trunk/subversion/libsvn_fs_x/changes.c (original) > +++ subversion/trunk/subversion/libsvn_fs_x/changes.c Tue Nov 19 > 22:17:09 2013 > @@ -413,17 +413,17 @@ svn_fs_x__read_changes_container(svn_fs_ > { > binary_change_t change; > > - change.flags = svn_packed__get_uint(changes_stream); > - change.path = svn_packed__get_uint(changes_stream); > + change.flags = (int)svn_packed__get_uint(changes_stream); > + change.path = (apr_size_t)svn_packed__get_uint(changes_stream); > > - change.copyfrom_rev = svn_packed__get_uint(changes_stream); > - change.copyfrom_path = svn_packed__get_uint(changes_stream); > + change.copyfrom_rev = > (svn_revnum_t)svn_packed__get_uint(changes_stream); > + change.copyfrom_path = > (apr_size_t)svn_packed__get_uint(changes_stream);
I'm not really familiar with the fsx disk format, but in all the other Subversion layers copyfrom_rev would be -1 (=SVN_INVALID_REVNUM) when not copied, so svn_revnum_t can't be one-on-one expressed as an uint. Is there a specific conversion that sets the revision to invalid in some other place? (Otherwise adding the cast from uint64 might hide a real problem) Bert