- 06 Jan, 2018 3 commits
-
-
Kenton Varda authored
-
Kenton Varda authored
This gives Sandstorm a way to move the membrane to a different process when desired.
-
Kenton Varda authored
-
- 03 Jan, 2018 2 commits
-
-
Kenton Varda authored
-
Kenton Varda authored
-
- 29 Dec, 2017 1 commit
-
-
Kenton Varda authored
Add totalSize() to list readers, like struct readers.
-
- 28 Dec, 2017 1 commit
-
-
Kenton Varda authored
-
- 27 Dec, 2017 1 commit
-
-
Kenton Varda authored
Extend membrane framework to make revocation easy.
-
- 26 Dec, 2017 1 commit
-
-
Kenton Varda authored
I realized upon trying to use this framework in Sandstorm that proper revocation was not easy to implement as-is. It's easy enough to revoke new calls, but canceling existing calls requires implementing a custom RequestHook and such. Since revocation is arguably the most important thing one might want to do with a membrane, this should be built-in.
-
- 23 Dec, 2017 19 commits
-
-
Kenton Varda authored
Change capnp compiler to use KJ filesystem API.
-
Kenton Varda authored
Also fixed a similar _MSC_VER guard that I realized was catching MinGW by accident.
-
Kenton Varda authored
-
Kenton Varda authored
-
Kenton Varda authored
-
Kenton Varda authored
The disk-backed implementations were already inherently threadsafe. Making this explicit allows callers to rely on it. This is particularly useful for SchemaParser, which is intended to be threadsafe.
-
Kenton Varda authored
-
Kenton Varda authored
-
Kenton Varda authored
Unfortunately, our cmake build scripts have historically passed -I flags specifying both the root of the source tree and the specific subdirectory in which the .capnp file is located. This is not correct, but since people do it (including our own cmake build), we need to not fail when this happens. Instead we print a warning.
-
Kenton Varda authored
Apparently, msync()'s parameters must be page-aligned, bah.
-
Kenton Varda authored
This allows detecting when two objects point to the same underlying file.
-
Kenton Varda authored
-
Kenton Varda authored
-
Kenton Varda authored
Fix Windows: SchemaParser::parseDiskFile() expects native paths, so use Windows-style absolute paths on Windows.
-
Kenton Varda authored
-
Kenton Varda authored
I got a little carried away here.
-
Kenton Varda authored
Otherwise, using kj::newDiskFilesystem() in the plugin complains.
-
Kenton Varda authored
This required some hairy backwards-compatibility hacks as the parseDiskFile() method is widely used.
-
Kenton Varda authored
In addition to cleaner code, this has the effect of fixing a number of issues: - Fixes #494: Windows paths are now parsed and handled a lot better. On Windows, backslashes are handled appropriately, as are absolute paths with drive letters. - Fixes #288: Specifing a source path starting with ".." without an appropriate --src-prefix will no longer cause output files to be generated outside of the specified output directory. Instead, the output name will be based on the absolute path, and a warning will be written since this is probably not what anyone wants. - It's no longer necessary for --src-prefix to exactly match character-for-character. Instead, the prefix and source paths are canonicalized before matching. It even works if one is relative and the other absolute. - Relative paths are now consistently always evaluated in path space, so ".." always cancels the previous path component and the OS/filesystem never even sees that it was there. This used to be the case in some places but not others. This behavior is important for symlink-heavy source trees: the path "foo/some-symlink/.." is now always designates "foo", rather than designating the parent directory of the symlink's target. This change does not update the code generator plugins nor the SchemaParser API. Those will come in separate commits.
-
- 22 Dec, 2017 2 commits
-
-
Kenton Varda authored
KJ_SWITCH_ONEOF should parenthesize its argument
-
Harris Hancock authored
This allows us to deal with Maybe<OneOf<...>> variables properly inside a KJ_IF_MAYBE block.
-
- 21 Dec, 2017 3 commits
-
-
Kenton Varda authored
Specifying input files that are not in the current directory and without specifying --src-prefix has always had pretty broken results: the compiler can actually break out of the specified output directory when creating output files! This will soon no longer be allowed. capnp-test, when run in an out-of-tree build, currently specifies such an unprefixed input, but got away with it because it was in the errors test, which doesn't actually output anything because there are input errors. We fix it by specifying a proper --src-prefix.
-
Kenton Varda authored
These use Win32 variants if and only if compiling for Windows.
-
Kenton Varda authored
-
- 20 Dec, 2017 5 commits
-
-
Kenton Varda authored
Implement KJ Filesystem API on Win32
-
Kenton Varda authored
Now that I know the actual reasoning behind the loop, I think it's not the best answer. Instead, we should retry removing the directory if it reports not-empty, but only a few times before we give up.
-
Kenton Varda authored
Yes, I'm using BTRFS now...
-
Kenton Varda authored
-
Kenton Varda authored
Windows symlinks really aren't meant to be treated like Unix symlinks, and we don't support creating symlinks anyway, so we don't even know if this code works...
-
- 19 Dec, 2017 2 commits
-
-
Kenton Varda authored
Fix multiple problems with connect() on non-glibc-Linux:
-
Kenton Varda authored
1. Correctly set nonblocking flag *before* calling connect(). (On glibc-Linux, we create the socket already in nonblocking mode, so this was never an issue.) 2. FDs could be leaked if connect fails. (This applies to glibc-Linux too, although connect() would have to fail immediately without blocking, which is unusual.)
-