Remove unnessecary uses of Foundation
This commit is contained in:
@@ -34,7 +34,7 @@
|
|||||||
"StencilSpecs/Nodes/*.swift"
|
"StencilSpecs/Nodes/*.swift"
|
||||||
],
|
],
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"Spectre": [ "~> 0.4.1" ],
|
"Spectre": [ "~> 0.5.0" ],
|
||||||
"PathKit": [ "~> 0.5.0" ]
|
"PathKit": [ "~> 0.5.0" ]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,18 +0,0 @@
|
|||||||
//
|
|
||||||
// Stencil.h
|
|
||||||
// Stencil
|
|
||||||
//
|
|
||||||
// Created by Kyle Fuller on 23/10/2014.
|
|
||||||
// Copyright (c) 2014 Cocode. All rights reserved.
|
|
||||||
// See LICENSE for more details.
|
|
||||||
//
|
|
||||||
|
|
||||||
#import <Foundation/Foundation.h>
|
|
||||||
|
|
||||||
//! Project version number for Stencil.
|
|
||||||
FOUNDATION_EXPORT double StencilVersionNumber;
|
|
||||||
|
|
||||||
//! Project version string for Stencil.
|
|
||||||
FOUNDATION_EXPORT const unsigned char StencilVersionString[];
|
|
||||||
|
|
||||||
// In this header, you should import all the public headers of your framework using statements like #import <Stencil/PublicHeader.h>
|
|
||||||
@@ -1,25 +1,26 @@
|
|||||||
import Foundation
|
import Foundation
|
||||||
import PathKit
|
import PathKit
|
||||||
|
|
||||||
|
|
||||||
// A class for loading a template from disk
|
// A class for loading a template from disk
|
||||||
public class TemplateLoader {
|
public class TemplateLoader {
|
||||||
public let paths:[Path]
|
public let paths: [Path]
|
||||||
|
|
||||||
public init(paths:[Path]) {
|
public init(paths: [Path]) {
|
||||||
self.paths = paths
|
self.paths = paths
|
||||||
}
|
}
|
||||||
|
|
||||||
public init(bundle:[NSBundle]) {
|
public init(bundle: [NSBundle]) {
|
||||||
self.paths = bundle.map {
|
self.paths = bundle.map {
|
||||||
return Path($0.bundlePath)
|
return Path($0.bundlePath)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public func loadTemplate(templateName:String) -> Template? {
|
public func loadTemplate(templateName: String) -> Template? {
|
||||||
return loadTemplate([templateName])
|
return loadTemplate([templateName])
|
||||||
}
|
}
|
||||||
|
|
||||||
public func loadTemplate(templateNames:[String]) -> Template? {
|
public func loadTemplate(templateNames: [String]) -> Template? {
|
||||||
for path in paths {
|
for path in paths {
|
||||||
for templateName in templateNames {
|
for templateName in templateNames {
|
||||||
let templatePath = path + Path(templateName)
|
let templatePath = path + Path(templateName)
|
||||||
|
|||||||
@@ -1,12 +1,11 @@
|
|||||||
import Foundation
|
|
||||||
import PathKit
|
import PathKit
|
||||||
|
|
||||||
|
|
||||||
public class IncludeNode : NodeType {
|
public class IncludeNode : NodeType {
|
||||||
public let templateName:String
|
public let templateName: String
|
||||||
|
|
||||||
public class func parse(parser:TokenParser, token:Token) throws -> NodeType {
|
public class func parse(parser: TokenParser, token: Token) throws -> NodeType {
|
||||||
let bits = token.contents.componentsSeparatedByString("\"")
|
let bits = token.contents.characters.split("\"", allowEmptySlices: true).map(String.init)
|
||||||
|
|
||||||
guard bits.count == 3 else {
|
guard bits.count == 3 else {
|
||||||
throw TemplateSyntaxError("'include' tag takes one argument, the template file to be included")
|
throw TemplateSyntaxError("'include' tag takes one argument, the template file to be included")
|
||||||
@@ -15,7 +14,7 @@ public class IncludeNode : NodeType {
|
|||||||
return IncludeNode(templateName: bits[1])
|
return IncludeNode(templateName: bits[1])
|
||||||
}
|
}
|
||||||
|
|
||||||
public init(templateName:String) {
|
public init(templateName: String) {
|
||||||
self.templateName = templateName
|
self.templateName = templateName
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,34 +1,36 @@
|
|||||||
import Foundation
|
|
||||||
|
|
||||||
class BlockContext {
|
class BlockContext {
|
||||||
class var contextKey:String { return "block_context" }
|
class var contextKey: String { return "block_context" }
|
||||||
|
|
||||||
var blocks:[String:BlockNode]
|
var blocks: [String:BlockNode]
|
||||||
|
|
||||||
init(blocks:[String:BlockNode]) {
|
init(blocks: [String:BlockNode]) {
|
||||||
self.blocks = blocks
|
self.blocks = blocks
|
||||||
}
|
}
|
||||||
|
|
||||||
func pop(blockName:String) -> BlockNode? {
|
func pop(blockName: String) -> BlockNode? {
|
||||||
return blocks.removeValueForKey(blockName)
|
return blocks.removeValueForKey(blockName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func any<Element>(elements:[Element], closure:(Element -> Bool)) -> Element? {
|
|
||||||
for element in elements {
|
extension CollectionType {
|
||||||
|
func any(closure: Generator.Element -> Bool) -> Generator.Element? {
|
||||||
|
for element in self {
|
||||||
if closure(element) {
|
if closure(element) {
|
||||||
return element
|
return element
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class ExtendsNode : NodeType {
|
|
||||||
let templateName:String
|
|
||||||
let blocks:[String:BlockNode]
|
|
||||||
|
|
||||||
class func parse(parser:TokenParser, token:Token) throws -> NodeType {
|
class ExtendsNode : NodeType {
|
||||||
|
let templateName: String
|
||||||
|
let blocks: [String:BlockNode]
|
||||||
|
|
||||||
|
class func parse(parser: TokenParser, token: Token) throws -> NodeType {
|
||||||
let bits = token.contents.componentsSeparatedByString("\"")
|
let bits = token.contents.componentsSeparatedByString("\"")
|
||||||
|
|
||||||
guard bits.count == 3 else {
|
guard bits.count == 3 else {
|
||||||
@@ -36,23 +38,23 @@ class ExtendsNode : NodeType {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let parsedNodes = try parser.parse()
|
let parsedNodes = try parser.parse()
|
||||||
guard (any(parsedNodes) { $0 is ExtendsNode }) == nil else {
|
guard (parsedNodes.any { $0 is ExtendsNode }) == nil else {
|
||||||
throw TemplateSyntaxError("'extends' cannot appear more than once in the same template")
|
throw TemplateSyntaxError("'extends' cannot appear more than once in the same template")
|
||||||
}
|
}
|
||||||
|
|
||||||
let blockNodes = parsedNodes.filter { node in node is BlockNode }
|
let blockNodes = parsedNodes.filter { node in node is BlockNode }
|
||||||
|
|
||||||
let nodes = blockNodes.reduce([String:BlockNode](), combine: { (accumulator, node:NodeType) -> [String:BlockNode] in
|
let nodes = blockNodes.reduce([String:BlockNode]()) { (accumulator, node:NodeType) -> [String:BlockNode] in
|
||||||
let node = (node as! BlockNode)
|
let node = (node as! BlockNode)
|
||||||
var dict = accumulator
|
var dict = accumulator
|
||||||
dict[node.name] = node
|
dict[node.name] = node
|
||||||
return dict
|
return dict
|
||||||
})
|
}
|
||||||
|
|
||||||
return ExtendsNode(templateName: bits[1], blocks: nodes)
|
return ExtendsNode(templateName: bits[1], blocks: nodes)
|
||||||
}
|
}
|
||||||
|
|
||||||
init(templateName:String, blocks:[String:BlockNode]) {
|
init(templateName: String, blocks: [String:BlockNode]) {
|
||||||
self.templateName = templateName
|
self.templateName = templateName
|
||||||
self.blocks = blocks
|
self.blocks = blocks
|
||||||
}
|
}
|
||||||
@@ -75,11 +77,12 @@ class ExtendsNode : NodeType {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class BlockNode : NodeType {
|
|
||||||
let name:String
|
|
||||||
let nodes:[NodeType]
|
|
||||||
|
|
||||||
class func parse(parser:TokenParser, token:Token) throws -> NodeType {
|
class BlockNode : NodeType {
|
||||||
|
let name: String
|
||||||
|
let nodes: [NodeType]
|
||||||
|
|
||||||
|
class func parse(parser: TokenParser, token: Token) throws -> NodeType {
|
||||||
let bits = token.components()
|
let bits = token.components()
|
||||||
|
|
||||||
guard bits.count == 2 else {
|
guard bits.count == 2 else {
|
||||||
@@ -92,7 +95,7 @@ class BlockNode : NodeType {
|
|||||||
return BlockNode(name:blockName, nodes:nodes)
|
return BlockNode(name:blockName, nodes:nodes)
|
||||||
}
|
}
|
||||||
|
|
||||||
init(name:String, nodes:[NodeType]) {
|
init(name: String, nodes: [NodeType]) {
|
||||||
self.name = name
|
self.name = name
|
||||||
self.nodes = nodes
|
self.nodes = nodes
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user