spf13 [Thu, 3 Oct 2013 13:44:45 +0000 (09:44 -0400)]
 
Enabling Nitro ('--stepAnalysis') again. Fix #58
spf13 [Wed, 2 Oct 2013 02:45:24 +0000 (22:45 -0400)]
 
Switching to the rjson library which is more friendly to human generated json.
spf13 [Tue, 1 Oct 2013 02:40:15 +0000 (22:40 -0400)]
 
fixed #85
spf13 [Tue, 1 Oct 2013 02:39:06 +0000 (22:39 -0400)]
 
Updating usage documentation to new interface
spf13 [Tue, 1 Oct 2013 02:38:32 +0000 (22:38 -0400)]
 
Restoring build and watch functionality
Kyle Mahan [Mon, 30 Sep 2013 02:37:29 +0000 (19:37 -0700)]
 
minor documentation cleanup.
- changed it's -> its where appropriate.
- added post/ parent directory above happy/ to the organization examples
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
windch [Mon, 30 Sep 2013 01:05:19 +0000 (14:05 +1300)]
 
Update filesystem.go
bugfix: .Files() called twice in line 253, 256 in site.go. thus source files captured twice.
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
spf13 [Sun, 29 Sep 2013 06:09:03 +0000 (02:09 -0400)]
 
Change the interface to use commands and flags instead of just flags.
Better organization of main (controller style) code.
spf13 [Sun, 29 Sep 2013 06:07:41 +0000 (02:07 -0400)]
 
go fmt so code
spf13 [Sun, 29 Sep 2013 06:07:05 +0000 (02:07 -0400)]
 
Better error message when no source content is found.
Noah Campbell [Sun, 29 Sep 2013 06:05:16 +0000 (23:05 -0700)]
 
Add the ability to set navbar li class to active
First cut at doing post html processing.  This utility can be used to
mark pages as active.
Noah Campbell [Wed, 25 Sep 2013 04:24:49 +0000 (21:24 -0700)]
 
Support index.html indexes in content directory
If a file named index.html exists in a directory, or root, it will be
rendered as if ugly urls are turned on.  This allows for top level
content to not need a supporting layout file and content in content.
This change should not affect anyone who is using the perscribed way.
I also cleaned up a bunch of one off functions in site.go.
Noah Campbell [Tue, 24 Sep 2013 21:41:21 +0000 (14:41 -0700)]
 
Fixes #80 - Homepage now renders correctly
I mistakenly make RenderHomePage a NOP.  Bad programmer.
Noah Campbell [Tue, 24 Sep 2013 21:36:22 +0000 (14:36 -0700)]
 
source: Fix failing build on windows
The +build directive was not being picked up.  Apparently needs a space
after the +build line.
Noah Campbell [Sat, 21 Sep 2013 03:05:20 +0000 (20:05 -0700)]
 
Fix breaking test cases on unix platform
Rename platform parameter file to agnostic name. Both darwin and linux
can share the same paramters.
Noah Campbell [Sat, 21 Sep 2013 00:24:25 +0000 (17:24 -0700)]
 
Create a TargetPath() method that provides OutFile
Moved the generation of the target path to the page breaking all
dependecies on Site.
Noah Campbell [Sat, 21 Sep 2013 00:03:43 +0000 (17:03 -0700)]
 
Section is determined by the source, not the url
This change allows for top level html content to exists.
Noah Campbell [Wed, 18 Sep 2013 22:48:36 +0000 (15:48 -0700)]
 
Fix fragments being AbsUrlified in final html
Found that fragments were getting the BaseURL applied creating a proper
anchor url and redirecting off the page.
Noah Campbell [Wed, 18 Sep 2013 21:21:27 +0000 (14:21 -0700)]
 
Allow non-markdown content in content directory
Allow content that is not markdown and does not need to be rendered to
exists in the content directory.  Currently any valid html or xml
document can exist.  Templates are applied to these documents as well.
If you need to have content that doesn't have templates or AbsUrlify
like operations, then continue to put this content in static and it will
be copied over.
Noah Campbell [Wed, 18 Sep 2013 18:52:30 +0000 (11:52 -0700)]
 
More expressive --check output
Noah Campbell [Wed, 18 Sep 2013 17:27:56 +0000 (10:27 -0700)]
 
Add renderer information to --check
Now reports if the page will be rendered or not and by which render
engine.
Noah Campbell [Wed, 18 Sep 2013 17:17:43 +0000 (10:17 -0700)]
 
Add IsRenderable to Page
As pages are read from the target, they will be assessed if they should
be rendered or not.  The logic for IsRenderable is in the parser/page.go
and looks for anything exception '<'.
Noah Campbell [Wed, 18 Sep 2013 16:15:46 +0000 (09:15 -0700)]
 
Fix parsing edge case of frontmatter
When the frontmatter contains a - (or other delimiter) close to the
closing frontmatter delimiter, frontmatter detection would fail.
Noah Campbell [Tue, 17 Sep 2013 22:52:40 +0000 (15:52 -0700)]
 
Merge remote-tracking branch 'origin/parser' into mrg_praser
Also brought in parse for github.com/noahcampbell/akebia
Conflicts:
	hugolib/page.go
	hugolib/page_test.go
Noah Campbell [Tue, 17 Sep 2013 21:16:06 +0000 (14:16 -0700)]
 
Move AbUrlify to post content transformation
Currently the a@href and script@src elements will have BaseUrl applied
to their elements prior to being written to disk.
Noah Campbell [Tue, 17 Sep 2013 20:04:28 +0000 (13:04 -0700)]
 
Add a transform step
This allows for the manipulation of the DOM.  This is expected to be
applied after the templates are rendered.
Noah Campbell [Fri, 13 Sep 2013 23:06:39 +0000 (16:06 -0700)]
 
Fix alias documentation.
Fixes #79
Noah Campbell [Fri, 13 Sep 2013 22:06:37 +0000 (15:06 -0700)]
 
Initialize HTMLRedirectAlias before ShowPlan()
Without it, no alias information is generated when running --check
Noah Campbell [Fri, 13 Sep 2013 21:46:34 +0000 (14:46 -0700)]
 
Add /index.html to unadorned alias paths
Bring code to be better in line with documentation.
Noah Campbell [Fri, 13 Sep 2013 17:30:27 +0000 (10:30 -0700)]
 
Remove RenderedContent from page.
The output is written directly to disk after being written.  Not
entirely sure why it was split into two steps.
Noah Campbell [Fri, 13 Sep 2013 04:18:13 +0000 (21:18 -0700)]
 
Move alias logic to target module
I want to move all logic to writing aliases to target so I can pave the
way for writing aliases specific to other runtimes (like .htaccess for
apache or a script for updating AWS or symlinking on a filesystem).
Noah Campbell [Thu, 12 Sep 2013 23:17:53 +0000 (16:17 -0700)]
 
Move alias rendering to target
Noah Campbell [Thu, 12 Sep 2013 17:48:59 +0000 (10:48 -0700)]
 
Normalize paths within hugo
filepath was used inconsistently throughout the hugolib.  With the
introduction of source and target modules, all path are normalized to
"/".  This simplifies the processing of paths.  It does mean that
contributors need to be aware of using path/filepath in any module other
than source or target is not recommended.  The current exception is
hugolib/config.go
Nelson Silva [Mon, 9 Sep 2013 11:43:30 +0000 (12:43 +0100)]
 
Added safeHtml template function
Noah Campbell [Thu, 5 Sep 2013 16:57:25 +0000 (09:57 -0700)]
 
Homepage "/" respects PublishDir
It wasn't taking the value of PublishDir into consideration for the
special case of the homepage "/".
Fixes #75
Noah Campbell [Thu, 5 Sep 2013 05:28:59 +0000 (22:28 -0700)]
 
Introduce source.Filesystem
This provides an abstraction over how files are processed by Hugo.  This
allows for alternatives like CMS systems or Dropbox, etc.
Noah Campbell [Wed, 4 Sep 2013 23:57:17 +0000 (16:57 -0700)]
 
Remove page module dependence on opening files
The site is responsible for reading files, page only operates on
buffers.
Noah Campbell [Wed, 4 Sep 2013 03:52:50 +0000 (20:52 -0700)]
 
Expand the ShowPlan functionality
Noah Campbell [Sun, 1 Sep 2013 16:56:58 +0000 (09:56 -0700)]
 
Move to target.Filesystem
Moving the ugly urls logic to the target.  There is still UglyUrl logic
in page for the permlink but this is dealing with the generate of urls.
Noah Campbell [Sun, 1 Sep 2013 16:24:03 +0000 (09:24 -0700)]
 
Add Translate to target
Translate handles Ugly Urls.
Noah Campbell [Sun, 1 Sep 2013 14:43:29 +0000 (07:43 -0700)]
 
Add file reporting to planner
Noah Campbell [Sun, 1 Sep 2013 04:13:04 +0000 (21:13 -0700)]
 
Adding Planner
Noah Campbell [Tue, 3 Sep 2013 22:38:20 +0000 (15:38 -0700)]
 
Code reorg, helpers.go has been decomposed.
It started with wanting to move templates in template bundles and the
rest followed.  I did my best to start grouping related functions
together, but there are some that I missed.  There is also the method
Urlize that seems to be a special function used in both worlds.  I'll
need to revisit this method.
Noah Campbell [Tue, 3 Sep 2013 21:51:06 +0000 (14:51 -0700)]
 
Date rendering unit tests in pages
Tests to ensure rendering dates in templates is working correctly.
Actually, I was running into invalid templates not giving warnings when
I was trying to render a date.
Noah Campbell [Tue, 3 Sep 2013 19:41:13 +0000 (12:41 -0700)]
 
Remove hugolib.HTML and hugolib.URL types
These types were not be rendered correctly by the html/template package.
Removing them gets the correct behavior.
Fixes #74
Noah Campbell [Sun, 1 Sep 2013 19:02:05 +0000 (12:02 -0700)]
 
Include building hugo docs as part of test.
If the building of the doc fails, tarvis will fail.  This will help with
pull requests.
Noah Campbell [Sun, 1 Sep 2013 19:02:05 +0000 (12:02 -0700)]
 
Include building hugo docs as part of test.
If the building of the doc fails, tarvis will fail.  This will help with
pull requests.
Fabrizio (Misto) Milo [Sun, 1 Sep 2013 00:47:21 +0000 (17:47 -0700)]
 
Add support for amber files
If a layout file ends with .amber it will interpreted as a Amber file
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Fabrizio (Misto) Milo [Sun, 1 Sep 2013 00:35:17 +0000 (17:35 -0700)]
 
Abstract html/template dependency
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Fabrizio (Misto) Milo [Sun, 1 Sep 2013 00:29:19 +0000 (17:29 -0700)]
 
Use s everywhere for consistency
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Noah Campbell [Sun, 1 Sep 2013 18:39:32 +0000 (11:39 -0700)]
 
Return an error (other than 0) when ./hugo fails
Being a good OS citizen so folks can compose hugo into their tool chain.
Also helps with git bisect run.
Mark Sanborn [Sun, 1 Sep 2013 04:07:22 +0000 (21:07 -0700)]
 
The <!--more--> (summary divider) now works even if it is on the same line as content
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Noah Campbell [Sun, 1 Sep 2013 03:00:57 +0000 (20:00 -0700)]
 
Small code cleanup
Noah Campbell [Sat, 31 Aug 2013 04:24:25 +0000 (21:24 -0700)]
 
Return an error with WritePublic
Noah Campbell [Sat, 31 Aug 2013 04:13:50 +0000 (21:13 -0700)]
 
Removing site.Directories.
Please revert if this is used somewhere.
Noah Campbell [Sat, 31 Aug 2013 00:18:05 +0000 (17:18 -0700)]
 
Externalize the writing of content to a target
Introducing the target module in hugo.  This provides the simple
interface for writing content given a label (filename) and a io.Reader
containing the content to be written.
If site.Target is not set, it defaults back to the original behavior of
writing to file system.
In hugolib/site_url_test.go I have an InMemoryTarget for testing
purposes and use it to see if the final output of a render matches.
Noah Campbell [Sat, 31 Aug 2013 00:14:36 +0000 (17:14 -0700)]
 
Ensure Section is set before returning Page object.
Noah Campbell [Sat, 31 Aug 2013 03:06:18 +0000 (20:06 -0700)]
 
Revert "Return errors when rendering"
This reverts commit 
e66ba5d2a7dd1a043a24bf86a271a5440b7b1385.
Fixed #69
Noah Campbell [Fri, 30 Aug 2013 21:38:33 +0000 (14:38 -0700)]
 
Cleanup formatting - go fmt ./...
Remember to run go fmt ./... before committing.  Looks sternly in mirror
Mark Sanborn [Thu, 29 Aug 2013 16:37:37 +0000 (09:37 -0700)]
 
Fixed bug where Url specified in front matter as pretty url wouldnt render
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Daniel Alan Miller [Thu, 29 Aug 2013 12:22:19 +0000 (21:52 +0930)]
 
Adding .Summary to page variables
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Fabrizio (Misto) Milo [Wed, 28 Aug 2013 16:33:10 +0000 (09:33 -0700)]
 
clean up logic
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Ross Lawley [Tue, 27 Aug 2013 09:09:50 +0000 (10:09 +0100)]
 
Refactored added RenderThingOrDefault and tests
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Conflicts:
	hugolib/site.go
Noah Campbell [Sun, 25 Aug 2013 04:27:41 +0000 (21:27 -0700)]
 
Using new parser.
Hugo Duncan [Tue, 20 Aug 2013 13:40:33 +0000 (09:40 -0400)]
 
Return any error reported by RenderHomePage
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Ross Lawley [Wed, 21 Aug 2013 09:37:14 +0000 (10:37 +0100)]
 
Wordpress summaries
Allow full control of summaries which can be rendered as html rather
than text.  Using a `<!--more-->` html comment in your markdown / rst
you can indiciate where the summary should end and have the summary
converted to html.
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Conflicts:
	hugolib/page_test.go
Ross Lawley [Wed, 21 Aug 2013 16:21:53 +0000 (17:21 +0100)]
 
Add 404.html for gh-pages
Signed-off-by: Noah Campbell <noahcampbell@gmail.com>
Noah Campbell [Fri, 23 Aug 2013 21:47:03 +0000 (14:47 -0700)]
 
RenderThing test cases
Provide unit test support RenderThing.
One observation is that creating the site.Tmpl variable is a one time
event.  site.Tmpl doesn't like additional templates with the same name.
This means that updating a template while in --watch mode requires
throwing away the entire Site object and creating a new one.  Not that
this is a bad idea, but it is something I discovered while working on
these unit tests.
Noah Campbell [Fri, 23 Aug 2013 21:40:02 +0000 (14:40 -0700)]
 
Test cases for ignoreDotFile
Meant to commit this earlier, but it's a basic unit test.
Noah Campbell [Fri, 23 Aug 2013 21:44:43 +0000 (14:44 -0700)]
 
Update .gitignore to ignore *.swo files
For the fellow vim user.
Noah Campbell [Tue, 20 Aug 2013 23:56:18 +0000 (16:56 -0700)]
 
Fix benchmark so the buffer is read each time.
The bytes.Buffer was exhausted after the first read.  Creating a new
reader each invocation catpures the correctly timing.
Noah Campbell [Wed, 14 Aug 2013 22:22:57 +0000 (15:22 -0700)]
 
Removing GetSection
Using GetXXX is not idiomatic to Go.  Also added a bunch of unit testing
around this method.
Noah Campbell [Fri, 23 Aug 2013 20:51:59 +0000 (13:51 -0700)]
 
Skip "dot" files in layout
As a vim user, .filename.swp files pop up.  This change prevents hugo
from reading those files.
Steve Francia [Wed, 21 Aug 2013 03:56:33 +0000 (20:56 -0700)]
 
Merge pull request #53 from hugoduncan/feature/print-error-on-invalid-index
Print error if index value in a page is wrong type
Steve Francia [Wed, 21 Aug 2013 03:55:56 +0000 (20:55 -0700)]
 
Merge pull request #52 from rozza/StaticSync
Static changes shouldn't be destructive to existing files
Steve Francia [Wed, 21 Aug 2013 03:54:51 +0000 (20:54 -0700)]
 
Merge pull request #51 from cabello/patch-3
Remove extra quotes from meta data
Steve Francia [Wed, 21 Aug 2013 03:54:31 +0000 (20:54 -0700)]
 
Merge pull request #50 from cabello/patch-2
Check .Prev and .Next pointers before using it
Steve Francia [Wed, 21 Aug 2013 03:54:06 +0000 (20:54 -0700)]
 
Merge pull request #49 from cabello/patch-1
Fix broken link to Index page
Hugo Duncan [Tue, 20 Aug 2013 20:39:26 +0000 (16:39 -0400)]
 
Print error if index value in a page is wrong type
This was causing a panic with no information displayed about the
page causing the error.
Ross Lawley [Tue, 20 Aug 2013 19:32:32 +0000 (20:32 +0100)]
 
Static changes shouldn't be destructive to existing files
Currently changing css deletes all the site published html when it copies.
Refs #46
Danilo Cabello [Tue, 20 Aug 2013 17:52:51 +0000 (13:52 -0400)]
 
Remove extra quotes from meta data
Danilo Cabello [Tue, 20 Aug 2013 16:13:27 +0000 (12:13 -0400)]
 
Check .Prev and .Next pointers before using it
Danilo Cabello [Tue, 20 Aug 2013 15:56:55 +0000 (11:56 -0400)]
 
Fix broken link to Index page
Steve Francia [Mon, 19 Aug 2013 12:32:36 +0000 (05:32 -0700)]
 
Merge pull request #46 from rawfalafel/sync_static
Sync files that have changed in the static directory
rawfalafel [Mon, 19 Aug 2013 05:17:37 +0000 (01:17 -0400)]
 
Watch StaticDir and sync to PublishDir on change
New behavior adds a special case for file changes inside the static directory to fsync PublishDir
Steve Francia [Sun, 18 Aug 2013 04:04:51 +0000 (21:04 -0700)]
 
Merge pull request #44 from cactus/avoid-redirect-with-slugs
avoid possible redirects with non-ugly slug urls
Steve Francia [Sun, 18 Aug 2013 04:04:14 +0000 (21:04 -0700)]
 
Merge pull request #43 from hugoduncan/feature/allow-xhtml-aliases
Enable aliases from .xhtml paths
Steve Francia [Sun, 18 Aug 2013 03:59:07 +0000 (20:59 -0700)]
 
Merge pull request #41 from rozza/skipStatic
Skip Static directory if its in your content directory
spf13 [Sun, 18 Aug 2013 03:53:35 +0000 (23:53 -0400)]
 
Merge branch 'noahcampbell-index_reporting'
Noah Campbell [Tue, 13 Aug 2013 21:58:50 +0000 (14:58 -0700)]
 
Formatting cleanup
Noah Campbell [Tue, 13 Aug 2013 21:47:14 +0000 (14:47 -0700)]
 
Removing the use of slash
An oversight on my behalf.  The FromSlash method is used when writing
out the public file name.  There is one place where the slashes are
required which is setting the output file.  I replaced those instances
with filepath.Join which should do the right thing depending on the OS.
Noah Campbell [Tue, 13 Aug 2013 17:46:05 +0000 (10:46 -0700)]
 
Detect missed index from front matter
Noah Campbell [Tue, 13 Aug 2013 17:44:40 +0000 (10:44 -0700)]
 
Return errors when rendering
spf13 [Sun, 18 Aug 2013 01:49:17 +0000 (21:49 -0400)]
 
Removing extra links on homepage
spf13 [Sat, 17 Aug 2013 12:40:18 +0000 (08:40 -0400)]
 
Adding "fork me on github" banner
spf13 [Sat, 17 Aug 2013 12:34:25 +0000 (08:34 -0400)]
 
Complete overhaul of the docs
Steve Francia [Sat, 17 Aug 2013 13:35:31 +0000 (06:35 -0700)]
 
Merge pull request #40 from VonC/clarify_uglyurls_flag
Clarify uglyurls flag.
elij [Fri, 16 Aug 2013 20:14:20 +0000 (13:14 -0700)]
 
avoid handling a redirect from slug to slug/
because the url lacks a trailing /, many webservers will issue a
redirect to the canonical url with trailing slash for directory index
w/index.htm(l).
Append a slash to avoid this.
Hugo Duncan [Fri, 16 Aug 2013 04:29:46 +0000 (00:29 -0400)]
 
Enable aliases from .xhtml paths
When redirecting an alias from a .xhtml path, served with default content type,
a redirect only works if the html element has a xmlns attribute.  This adds the
attribute when the alias path ends in .xhtml
Ross Lawley [Thu, 15 Aug 2013 18:58:34 +0000 (19:58 +0100)]
 
Skip Static directory if its in your content directory
Allows organisation where all source files are in one directory:
```
`config.yaml`:
contentdir: "source"
staticdir: "source/static"
...
 .
	└── source
		├── post
		|	├── firstpost.md	// <- http://site.com/post/firstpost.html
		|	└── secondpost.md	// <- http://site.com/post/secondpost.html
		└── static
			└── css
				 └── site.css	// <- http://site.com/css/site.css
```