Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Reimplement files.FileLines #2707

Merged
merged 11 commits into from
Sep 4, 2018
Merged

Reimplement files.FileLines #2707

merged 11 commits into from
Sep 4, 2018

Conversation

mfelsche
Copy link
Contributor

@mfelsche mfelsche commented May 22, 2018

  • remove File.line
  • add ponytest.UnitTest.set_up method for initializing test state that needs a TestHelper (i.e. for getting an Env)

Fixes #2185

@mfelsche
Copy link
Contributor Author

This one still needs some docstrings and some manual changelog entries.

@SeanTAllen
Copy link
Member

I'm uncomfortable with the iso change on buffered.Reader not going through some sort of discussion or RFC. Its out of scope for "Reimplement files.FileLines" and we should have a bit of discussion on a breaking change that expands that scope.

@mfelsche
Copy link
Contributor Author

I know it's not classy to mangle it all together in one PR. I am happy to turn into RFC or separate PR what needs to be turned. This is my desired state of FileLines and i wanted to present it as such for discussion.

I just wanted to check back, if the outcome is in any way desirable: Having FileLines return String iso^, now being consistent with pretty much every method to retrieve bytes from some external resource. If this is not wanted, i can easily revert this breaking change and we all forget about it.

@mfelsche
Copy link
Contributor Author

@SeanTAllen would you find an RFC appropriate for the iso change in buffered.Reader?

@SeanTAllen
Copy link
Member

I think we should discuss what is appropriate during sync.

@mfelsche mfelsche added needs discussion during sync do not merge This PR should not be merged at this time labels May 23, 2018
@slfritchie
Copy link
Contributor

From today's Pony sync call: this work is inspired by #2185.

@mfelsche
Copy link
Contributor Author

We discussed this on the sync call and decided to make the change on buffered.Reader go through the RFC process, before merging this, as this is a breaking change, although minor.

This also needs to have the examples fixed.

@mfelsche
Copy link
Contributor Author

mfelsche commented Jun 9, 2018

@SeanTAllen this is ready for a review.

@mfelsche
Copy link
Contributor Author

mfelsche commented Jun 9, 2018

Well actually this still contains a bug. It is not correctly resetting the file position in all cases, might be a bug in the try ... then ... expression, not calling the then clause under certain circumstances. I will investigate.

@mfelsche mfelsche added do not merge This PR should not be merged at this time changelog - changed Automatically add "Changed" CHANGELOG entry on merge and removed changelog - changed Automatically add "Changed" CHANGELOG entry on merge labels Jun 10, 2018
@mfelsche
Copy link
Contributor Author

It seems to work correctly on most platforms, but is failing on windows due to some condition i do not fully understand. Appveyor fails with:

C:\projects\ponyc\packages\files\_test.pony:1024: Assert eq failed.  Expected ( b c d) == (b c d)

Which is, in the test it opens a file with the following contents: a\nb\nc\nd. It is seeking to position 2 from the start of the file and iterates over the lines. It seems, to be returning an empty first line although the file position should be behind the first \n. Do you maybe have a clue here @kulibali ? Could it be there is a \r slipping into the file somehow? Or is the line handling in buffered.reader on windows wrong?

@chalcolith
Copy link
Member

I'll take a look later today.

@chalcolith
Copy link
Member

Yeah, by default Windows will write \r\n to a file whenever you try to write \n. Here's a patch to default to "binary" mode, which I think is more sane in this day and age:

diff --git a/src/libponyrt/lang/directory.c b/src/libponyrt/lang/directory.c
index 5c59f940..e27b4165 100644
--- a/src/libponyrt/lang/directory.c
+++ b/src/libponyrt/lang/directory.c
@@ -116,22 +116,38 @@ PONY_API const char* ponyint_windows_readdir(WIN32_FIND_DATA* find)

PONY_API int ponyint_o_rdonly()
{
+#if defined(PLATFORM_IS_WINDOWS)
+  return _O_RDONLY | _O_BINARY;
+#else
  return O_RDONLY;
+#endif
}

PONY_API int ponyint_o_rdwr()
{
+#if defined(PLATFORM_IS_WINDOWS)
+  return _O_RDWR | _O_BINARY;
+#else
  return O_RDWR;
+#endif
}

PONY_API int ponyint_o_creat()
{
+#if defined(PLATFORM_IS_WINDOWS)
+  return _O_CREAT | _O_BINARY;
+#else
  return O_CREAT;
+#endif
}

PONY_API int ponyint_o_trunc()
{
+#if defined(PLATFORM_IS_WINDOWS)
+  return _O_TRUNC | _O_BINARY;
+#else
  return O_TRUNC;
+#endif
}

#if defined(PLATFORM_IS_POSIX_BASED)

Maybe this should be a separate PR?

@mfelsche
Copy link
Contributor Author

Yes, i think so too, +1 for separate PR. This PR has been digging up some corpses already, one more is just fine.

chalcolith added a commit to chalcolith/ponyc that referenced this pull request Jun 27, 2018
By default Windows will translate `\n` to `\r\n` when writing to files, and vice versa when reading.  This interacts poorly with seeking in the file first (ponylang#2707).  This change makes opening files via the `files` module always use "binary" mode, which will not do any translation.
chalcolith added a commit to chalcolith/ponyc that referenced this pull request Jun 27, 2018
By default Windows will translate `\n` to `\r\n` when writing to files, and vice versa when reading.  This interacts poorly with seeking in the file first (ponylang#2707).  This change makes opening files via the `files` package always use "binary" mode, which will not do any translation.
@mfelsche
Copy link
Contributor Author

mfelsche commented Jul 1, 2018

I rebased, added some docstrings and added manual changelog entries for what has been fixed, changed and added.

If CI is fine this is ready to be merged.

@mfelsche mfelsche removed the do not merge This PR should not be merged at this time label Jul 1, 2018
@mfelsche
Copy link
Contributor Author

mfelsche commented Jul 1, 2018

Release notes draft

The function File.line(), which was returning a single line from the file as a string has been removed in favor of using File.lines() or FileLines directly.

In order to only get a single line from a file, and not iterate over the whole file, you can use the following code snippet:

let line = my_file.lines().next()?

@mfelsche
Copy link
Contributor Author

mfelsche commented Jul 4, 2018

Looking at this from afar i recognize that FileLines does not consume the file i.e. advancing the cursor up to where it was reading from the file in general makes sense, but always resetting it to where it was before might actually be counterintuitive.

The general expectation is (i suppose) that whenever i read something from a file the cursor is advanced by that amount. FileLines is usually reading more, buffering these contents.

It might be more reasonable to advance the cursor beyond the trailing linebreak of the returned line? Any thoughts on this?

@winksaville
Copy link
Contributor

winksaville commented Jul 4, 2018 via email

@mfelsche
Copy link
Contributor Author

Thanks @winksaville for your input. I think the same way. I would just like to ask @SeanTAllen for his, as he was around when the decision for the reimplementation of FileLines was made during a sync call (I remember what you did last summer!).

Gonna change the logic accordingly.

@mfelsche
Copy link
Contributor Author

mfelsche commented Jul 16, 2018

There seem to be a segfault when running the stdlib tests on armhf:

PONYPATH=.:/usr/cross/lib build/debug/ponyc --triple=arm-unknown-linux-gnueabihf --cpu=cortex-a9 --link-arch=armv7-a --linker='arm-linux-gnueabihf-gcc' --checktree --verify packages/stdlib
Building builtin -> /home/pony/project/packages/builtin
Building packages/stdlib -> /home/pony/project/packages/stdlib
Building ponytest -> /home/pony/project/packages/ponytest
Building time -> /home/pony/project/packages/time
Building collections -> /home/pony/project/packages/collections
Building assert -> /home/pony/project/packages/assert
Building encode/base64 -> /home/pony/project/packages/encode/base64
Building buffered -> /home/pony/project/packages/buffered
Building builtin_test -> /home/pony/project/packages/builtin_test
Building bureaucracy -> /home/pony/project/packages/bureaucracy
Building promises -> /home/pony/project/packages/promises
Building capsicum -> /home/pony/project/packages/capsicum
Building files -> /home/pony/project/packages/files
Building term -> /home/pony/project/packages/term
Building strings -> /home/pony/project/packages/strings
Building signals -> /home/pony/project/packages/signals
Building random -> /home/pony/project/packages/random
Building cli -> /home/pony/project/packages/cli
Building collections/persistent -> /home/pony/project/packages/collections/persistent
Building crypto -> /home/pony/project/packages/crypto
Building format -> /home/pony/project/packages/format
Building debug -> /home/pony/project/packages/debug
Building glob -> /home/pony/project/packages/glob
Building regex -> /home/pony/project/packages/regex
Building ini -> /home/pony/project/packages/ini
Building itertools -> /home/pony/project/packages/itertools
Building json -> /home/pony/project/packages/json
Building logger -> /home/pony/project/packages/logger
Building math -> /home/pony/project/packages/math
Building net -> /home/pony/project/packages/net
Building options -> /home/pony/project/packages/options
Building ponybench -> /home/pony/project/packages/ponybench
Building process -> /home/pony/project/packages/process
Building backpressure -> /home/pony/project/packages/backpressure
Building serialise -> /home/pony/project/packages/serialise
Building net/ssl -> /home/pony/project/packages/net/ssl
Generating
 Reachability
 Selector painting
 Data prototypes
 Data types
 Function prototypes
 Functions
 Descriptors
Optimising
Verifying
Writing ./stdlib.o
Linking ./stdlib
qemu-arm-static --cpu cortex-a9 -L /usr/local/arm-linux-gnueabihf/libc ./stdlib --sequential
qemu: uncaught target signal 11 (Segmentation fault) - core dumped
make: *** [test-stdlib] Segmentation fault
Exited with code 2

@dipinhora does that ring a bell to you?

@dipinhora
Copy link
Contributor

@mfelsche That output from qemu happens if there is a segfault. Without a backtrace there isn't much to go on to determine what might be occurring.

If you think it might be a transient issue (since all the other armhf builds passed), you can try re-running the failed job.

@mfelsche
Copy link
Contributor Author

Alrighty, all tests have passed. Thx @dipinhora !

@SeanTAllen or @jemc this is ready for review.

@dipinhora
Copy link
Contributor

@mfelsche due to the release of 0.24.1 and its related changes to the CHANGELOG file, please merge or rebase onto master and adjust your CHANGELOG entries into the appropriate area of "unreleased" in the CHANGELOG file.

@mfelsche
Copy link
Contributor Author

updated changelog and rebased. :)

Matthias Wahl and others added 10 commits August 24, 2018 12:31
for use-cases where the Env from the TestHelper is needed to initialize state in a test, which is very hard to do in the constructor (e.g. for creating temporary directories)
Making it maintain its own cursor through the file for not disturbing other operations on the same file.

Removed File.line as agreed upon in https://github.com/ponylang/ponyc/issues/2185\#issuecomment-329281827
to be exact it is advanced to after the linebreak
@mfelsche mfelsche merged commit b73b4c4 into master Sep 4, 2018
@mfelsche mfelsche deleted the filelines branch September 4, 2018 08:36
@SeanTAllen SeanTAllen mentioned this pull request Sep 4, 2018
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants