2007/5/31, Alexei Zakharov <[EMAIL PROTECTED]>:

Hi Paulex,

Thanks for your attention. About the fix. Please look carefully at my
commit [1]:

I_32
getPlatformIsWriteOnly (JNIEnv * env, char *path)
{
+  HANDLE fHandle = CreateFile(path, GENERIC_READ, FILE_SHARE_READ,
+      NULL, OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL);
+
+  if (fHandle == INVALID_HANDLE_VALUE) {
+    return 1;
+  }
+
+  CloseHandle(fHandle);
   return 0;
}

The difference is in the function name. I've patched the
"getPlatformIsWriteOnly" function that checks "if the file is
write-only - i.e. *NOT* readable".  So IMO it is quite logical to
return 1 if we can't read from the file and 0 otherwise. Did I miss
something?


Oops, you are right, I'm looking at the wrong method, sorry for the confuse.


Regards,

[1]
http://svn.apache.org/viewvc/harmony/enhanced/classlib/trunk/modules/luni/src/main/native/luni/windows/helpers.c?p2=%2Fharmony%2Fenhanced%2Fclasslib%2Ftrunk%2Fmodules%2Fluni%2Fsrc%2Fmain%2Fnative%2Fluni%2Fwindows%2Fhelpers.c&p1=%2Fharmony%2Fenhanced%2Fclasslib%2Ftrunk%2Fmodules%2Fluni%2Fsrc%2Fmain%2Fnative%2Fluni%2Fwindows%2Fhelpers.c&r1=541367&r2=541366&view=diff&pathrev=541367

2007/5/31, Yang Paulex <[EMAIL PROTECTED]>:
> Alexei,
>
> I got some problems on windows after this fix, seems the return value in
> patch below should be reversed?
>
>  I_32
>  getPlatformIsReadable (JNIEnv * env, char *path)
>  {
> -  return 1;
> +  HANDLE fHandle = CreateFile(path, GENERIC_READ, FILE_SHARE_READ,
> +      NULL, OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL);
> +
> +  if (fHandle == INVALID_HANDLE_VALUE) {
> +    return 1; //Paulex: seems should return 0 here, which means not
> readable.
> +  }
> +
> +  CloseHandle(fHandle);
> +  return 0; //Paulex: seems should return 1 here, which means readable.
>  }
>
> 2007/5/30, Alexei Zakharov (JIRA) <[EMAIL PROTECTED]>:
> >
> >
> >      [
> >
https://issues.apache.org/jira/browse/HARMONY-517?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
> >
> > Alexei Zakharov closed HARMONY-517.
> > -----------------------------------
> >
> >
> > Fix was verified by Ruth. Issue closed.
> >
> > > [classlib][luni] File.listFiles returns empty list but should return
> > null
> > >
> >
-------------------------------------------------------------------------
> > >
> > >                 Key: HARMONY-517
> > >                 URL:
https://issues.apache.org/jira/browse/HARMONY-517
> > >             Project: Harmony
> > >          Issue Type: Bug
> > >          Components: Classlib
> > >            Reporter: Mark Hindess
> > >            Assignee: Alexei Zakharov
> > >            Priority: Minor
> > >         Attachments: Harmony-517.diff,
reading.chmod.0.directory.diff
> > >
> > >
> > > On unix, if I create a directory and then change the permissions to
make
> > it unreadable ("chmod 0 dir") then File.listFiles() on that directory
on
> > RI returns null but on Harmony it returns the empty list.
> >
> > --
> > This message is automatically generated by JIRA.
> > -
> > You can reply to this email to add a comment to the issue online.
> >
> >
>
>
> --
> Paulex Yang
> China Software Development laboratory
> IBM
>


--
Alexei Zakharov,
Intel ESSD




--
Paulex Yang
China Software Development laboratory
IBM

Reply via email to