Commit Graph

516 Commits

Author SHA1 Message Date
Havoc Pennington
ac878d653c include the message in Tokens#Problem#toString
Required adding accessor for "what" for use in tests
2012-06-18 22:58:04 -04:00
Havoc Pennington
b3ac8d0539 bump to 0.4.1 in the README 2012-05-24 09:18:34 -04:00
Havoc Pennington
4462c667f9 bump to 0.4.2-SNAPSHOT 2012-05-22 17:26:51 -04:00
Havoc Pennington
9bbb7d7ac4 v0.4.1 2012-05-22 17:26:12 -04:00
Havoc Pennington
fea5d6d478 bump to 0.4.1-SNAPSHOT 2012-05-22 09:04:31 -04:00
Heiko Seeberger
11b9af503a closes #16: Publish as OSGi bundle 2012-05-21 11:51:08 +02:00
Havoc Pennington
765b61a80b explicitly set -source 1.6 -target 1.6 2012-05-14 12:21:18 -04:00
Havoc Pennington
fa038eac67 add note about only supporting Java 6 and above. 2012-05-14 12:07:55 -04:00
Havoc Pennington
445a700c53 add notes on Akka 2.0 embedded config limitations to HOCON.md
These were already in the README but people may jump straight
to the spec, so add them there too.
2012-05-14 12:02:35 -04:00
Havoc Pennington
9a2e9a8bde add some notes about features that aren't in Play/Akka 2.0 2012-04-13 10:37:02 -04:00
Havoc Pennington
2e5b1eaa1b fix formatting of prior NEWS change 2012-04-13 11:27:11 -03:00
Havoc Pennington
c8632d9458 note the moved publish location in NEWS 2012-04-13 10:26:15 -04:00
Havoc Pennington
06d6fc5ee3 mention new include syntax in the README 2012-04-13 10:08:39 -04:00
Havoc Pennington
9b7d2a6469 remove "Future Directions" from README, the Future is Now! 2012-04-13 10:06:36 -04:00
Havoc Pennington
0adc9152d1 Show how to create a Settings class to encapsulate your Config 2012-04-13 10:06:08 -04:00
Havoc Pennington
85a4edab59 fix a couple links in the API docs 2012-04-13 09:39:39 -04:00
Havoc Pennington
8159cf3ed4 version to 0.4.0-SNAPSHOT (put SNAPSHOT back) 2012-04-13 09:30:12 -04:00
Havoc Pennington
b35dfb67b2 Optimistically update the README with Maven Central information 2012-04-12 21:48:35 -04:00
Havoc Pennington
b88fd55f86 another NEWS tweak 2012-04-12 21:45:43 -04:00
Havoc Pennington
3ce0997adc don't mess up the PGP plugin
No need to add the settings a second time, which
resulted in signing the signatures.

No need to use GPG, it uses its built-in stuff.
2012-04-12 21:40:57 -04:00
Havoc Pennington
5093213c12 NEWS.md updates 2012-04-12 21:38:34 -04:00
Havoc Pennington
387e106856 Add ConfigRenderOptions and ConfigValue#render(options)
This mostly lets you choose whether you want whitespace and
comments, and somewhat as a side effect, you can get plain
JSON by turning off comments.
2012-04-12 21:34:59 -04:00
Havoc Pennington
985958521d more fully test origin serialization and clean up code a bit
Mostly removing impossible codepaths.
2012-04-12 17:36:09 -04:00
Havoc Pennington
aea95bd228 fix some warnings from findbugs
Only one of these, possible incomplete skip
from DataInput.skipBytes(), was a real problem
I think.
2012-04-12 15:33:15 -04:00
Havoc Pennington
db3a676c02 Update build: sbt 0.11.2, maven central publish config, gpg 2012-04-12 15:21:06 -04:00
Havoc Pennington
f0e4dfd806 remove ConfigSubstitution, it was a serialization compat shim
The serialization-pocalypse removes the need for this shim.
2012-04-12 13:21:10 -04:00
Havoc Pennington
388d85fb5d Serialization-pocalypse: change serialization format
The previous use of Java's default serialization dumped
all implementation-detail class names and fields into the serialization,
making it basically impossible to improve the implementation.

Two strategies here:
 - prohibit serialization of unresolved configs, which are
   the location of a lot of implementation detail
 - delegate all serialization to an Externalizable
   SerializedConfigValue class, which serializes
   using fields that have lengths. Unknown fields
   can thus be skipped and we can write code to
   support obsolete fields, and so on.

As a side effect, this makes the serialization far more compact
because we don't need the Java per-class header noise, and we
jump through some hoops to avoid writing out duplicate ConfigOrigin
information. It still isn't super-compact compared to something
like protobuf but it's a lot less insane.
2012-04-12 13:04:14 -04:00
Havoc Pennington
d14d8cae78 add a couple tips about debugging configs to the README 2012-04-12 00:54:14 -04:00
Havoc Pennington
4add0330d8 fix formatting of a comment in Parseable.java 2012-04-09 19:19:04 -04:00
Havoc Pennington
2dc420ccf0 If include statements from a cycle, throw a nicer error 2012-04-09 19:18:46 -04:00
Havoc Pennington
36f4e2e61a write release notes for 0.NEXT 2012-04-09 12:49:38 -04:00
Havoc Pennington
6490226e8f Implement parsing url() file() classpath() includes 2012-04-09 12:26:44 -04:00
Havoc Pennington
05c60ea0fb Make string, stream parsers support classpath includes
Previously they didn't support any kind of include.
2012-04-09 12:26:44 -04:00
Havoc Pennington
386613909b hack ConfigImplUtil.urlToFile to make "file://whatever" with two slashes work
This compounds the wrongness of that method.
2012-04-09 12:26:44 -04:00
Havoc Pennington
3b7d99a797 Groundwork for the new file() url() classpath() include syntax
This patch doesn't have the parser just the implementation
2012-04-09 12:26:39 -04:00
Havoc Pennington
cdd3e127fc allow setting a ClassLoader on ConfigParseOptions
This should have been the API, rather than adding a loader
parameter to ConfigFactory methods.

By adding to the options, the class loader is inherited by
any included files or urls. Previously, it was only inherited
by included classpath resources, but including classpath resources
from non-classpath resources would lose track of the class loader.

The methods that take a ClassLoader are now convenience API that
just adds that passed-in loader to your ConfigParseOptions.
2012-04-09 10:29:35 -04:00
Havoc Pennington
ce352691ff make clear in docs that ConfigIncludeContext should not be implemented by apps 2012-04-09 10:28:51 -04:00
Havoc Pennington
5e7b929b65 Split ConfigIncludeContext from Parseable out into its own file 2012-04-09 10:28:51 -04:00
Havoc Pennington
8c6b204905 Specify url() classpath() file() includes in the spec 2012-04-09 10:28:45 -04:00
Havoc Pennington
3e46429871 split SimpleIncluder and fromBasename out of ConfigImpl.java
Just to have less stuff in one big file.
2012-04-06 19:41:30 -04:00
Havoc Pennington
69e6164b30 Support += convenience syntax
a += b

transforms to

    a += ${?a} [b]
2012-04-06 10:58:00 -04:00
Havoc Pennington
27096e262f Minor spec editing 2012-04-06 00:52:53 -04:00
Havoc Pennington
47e168a92f Implement array and object concatenation
path : [ /bin ]
  path : ${path} [ /usr/bin ]

This added very few lines of code or bytecode!
It's just a natural extension of the existing
string concatenation.

But it did add a fair few lines of specification
and tests.
2012-04-06 00:35:47 -04:00
Havoc Pennington
8189be0f16 make ConfigException.WrongType extra constructors public
and let Eclipse reformat a bit
2012-04-05 22:49:14 -04:00
Havoc Pennington
11a43d701c add very basic ConcatenationTest for string concatenation 2012-04-05 16:02:52 -04:00
Havoc Pennington
80eac565c6 remove ignoresFallbacks param from AbstractConfigValue.newCopy
Only one subclass ever used this, SimpleConfigObject

So now we have withFallbacksIgnored that asserts they are
already ignored, for the other classes, and has a special
SimpleConfigObject implementation.
2012-04-05 15:24:24 -04:00
Havoc Pennington
a8d444e19f Improve the spec's description of self-referential semantics 2012-04-05 14:59:05 -04:00
Havoc Pennington
401f2dc176 don't need to replace() in ConfigConcatenation
Because the cycle is detected by the nested ConfigReference.
2012-04-05 14:55:21 -04:00
Havoc Pennington
8fdc372330 Assert that delayed merge stacks don't contain other delayed merge stacks 2012-04-05 14:21:11 -04:00
Havoc Pennington
b696dbee38 Fix semantics of references from _inside_ a field value to that field
vs. the value itself being a reference to the field.

So this looks "backward":

  a : ${a}

vs. this does not:

  a : { b : ${a} }
2012-04-05 14:16:42 -04:00