*
* @package org.cocur.slugify
* @author Florian Eckerstorfer <florian@eckerstorfer.co>
* @author Marchenko Alexandr
* @copyright 2012-2014 Florian Eckerstorfer
* @license http://www.opensource.org/licenses/MIT The MIT License
*/
interface SlugifyInterface
{
/**
* Return a URL safe version of a string.
*
* @param string $string
* @param string|array|null $options
*
* @return string
*
* @api
*/
public function slugify(string $string, array|string|null $options = null): string;
}
"syntax error, unexpected '|', expecting variable (T_VARIABLE) (View: /home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/web/app/themes/tfs/resources/views/single.blade.php)"
*
* @param string $__path
* @param array $__data
* @return string
*/
protected function evaluatePath($__path, $__data)
{
$obLevel = ob_get_level();
ob_start();
extract($__data, EXTR_SKIP);
// We'll evaluate the contents of the view inside a try/catch block so we can
// flush out any stray output that might get out before an error occurs or
// an exception is thrown. This prevents any partial views from leaking.
try {
include $__path;
} catch (Throwable $e) {
$this->handleViewException($e, $obLevel);
}
return ltrim(ob_get_clean());
}
/**
* Handle a view exception.
*
* @param \Throwable $e
* @param int $obLevel
* @return void
*
* @throws \Throwable
*/
protected function handleViewException(Throwable $e, $obLevel)
{
while (ob_get_level() > $obLevel) {
ob_end_clean();
}
*
* @package org.cocur.slugify
* @author Florian Eckerstorfer <florian@eckerstorfer.co>
* @author Marchenko Alexandr
* @copyright 2012-2014 Florian Eckerstorfer
* @license http://www.opensource.org/licenses/MIT The MIT License
*/
interface SlugifyInterface
{
/**
* Return a URL safe version of a string.
*
* @param string $string
* @param string|array|null $options
*
* @return string
*
* @api
*/
public function slugify(string $string, array|string|null $options = null): string;
}
"syntax error, unexpected '|', expecting variable (T_VARIABLE)"
public function unregister()
{
spl_autoload_unregister(array($this, 'loadClass'));
if (null !== $this->vendorDir) {
unset(self::$registeredLoaders[$this->vendorDir]);
}
}
/**
* Loads the given class or interface.
*
* @param string $class The name of the class
* @return true|null True if loaded, null otherwise
*/
public function loadClass($class)
{
if ($file = $this->findFile($class)) {
$includeFile = self::$includeFile;
$includeFile($file);
return true;
}
return null;
}
/**
* Finds the path to the file where the class is defined.
*
* @param string $class The name of the class
*
* @return string|false The path if found, false otherwise
*/
public function findFile($class)
{
// class map lookup
if (isset($this->classMap[$class])) {
return $this->classMap[$class];
}
*
* For the full copyright and license information, please view the LICENSE.md
* file that was distributed with this source code.
*
* ------------------------------------------------------------------
*/
declare(strict_types=1);
namespace TOC;
use Cocur\Slugify\Slugify;
use Cocur\Slugify\SlugifyInterface;
/**
* UniqueSlugify creates slugs from text without repeating the same slug twice per instance
*
* @author Casey McLaughlin <caseyamcl@gmail.com>
*/
class UniqueSlugify implements SlugifyInterface
{
/**
* @var SlugifyInterface
*/
private $slugify;
/**
* @var array
*/
private $used;
/**
* Constructor
*
* @param SlugifyInterface|null $slugify
*/
public function __construct(?SlugifyInterface $slugify = null)
{
$this->used = array();
$this->slugify = $slugify ?: new Slugify();
/**
* @return void
*/
private static function initializeIncludeClosure()
{
if (self::$includeFile !== null) {
return;
}
/**
* Scope isolated include.
*
* Prevents access to $this/self from included files.
*
* @param string $file
* @return void
*/
self::$includeFile = \Closure::bind(static function($file) {
include $file;
}, null, null);
}
}
"/home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/vendor/caseyamcl/toc/src/UniqueSlugify.php"
public function unregister()
{
spl_autoload_unregister(array($this, 'loadClass'));
if (null !== $this->vendorDir) {
unset(self::$registeredLoaders[$this->vendorDir]);
}
}
/**
* Loads the given class or interface.
*
* @param string $class The name of the class
* @return true|null True if loaded, null otherwise
*/
public function loadClass($class)
{
if ($file = $this->findFile($class)) {
$includeFile = self::$includeFile;
$includeFile($file);
return true;
}
return null;
}
/**
* Finds the path to the file where the class is defined.
*
* @param string $class The name of the class
*
* @return string|false The path if found, false otherwise
*/
public function findFile($class)
{
// class map lookup
if (isset($this->classMap[$class])) {
return $this->classMap[$class];
}
/**
* @var HTML5
*/
private $htmlParser;
/**
* @var SlugifyInterface
*/
private $slugifier;
/**
* Constructor
*
* @param HTML5|null $htmlParser
* @param SlugifyInterface|null $slugify
*/
public function __construct(?HTML5 $htmlParser = null, ?SlugifyInterface $slugify = null)
{
$this->htmlParser = $htmlParser ?? new HTML5();
$this->slugifier = $slugify ?? new UniqueSlugify();
}
/**
* Fix markup
*
* @param string $markup
* @param int $topLevel
* @param int $depth
* @return string Markup with added IDs
* @throws RuntimeException
*/
public function fix(string $markup, int $topLevel = 1, int $depth = 6): string
{
if (! $this->isFullHtmlDocument($markup)) {
$partialID = uniqid('toc_generator_');
$markup = sprintf("<body id='%s'>%s</body>", $partialID, $markup);
}
$domDocument = $this->htmlParser->loadHTML($markup);
$domDocument->preserveWhiteSpace = true; // do not clobber whitespace
<?php
namespace App\View\Composers;
use DOMDocument;
use Roots\Acorn\View\Composer;
class BlogPost extends Composer
{
protected static $views = [
'partials.content-single',
];
public function override()
{
$fields = get_fields();
$htmlContent = apply_filters( 'the_content', get_the_content() );
$markupFixer = new \TOC\MarkupFixer();
$tocGenerator = new \TOC\TocGenerator();
$htmlContent = $markupFixer->fix($htmlContent);
$fields['toc'] = $tocGenerator->getOrderedHtmlMenu($htmlContent);
$fields['the_content'] = $htmlContent;
$fields['the_category'] = $this->getCategory();
return $fields;
}
public function getCategory() {
$category = null;
if(get_the_terms(get_the_id(), 'category')) {
foreach(get_the_terms(get_the_id(), 'category') as $term) {
if($term->name !== "Blog" && $term->name !== "Events" && $term->name !== "News") {
$category = $term;
return $category;
}
}
}
*/
public function compose(View $view)
{
$this->view = $view;
$this->data = new Fluent($view->getData());
$view->with($this->merge());
}
/**
* Data to be merged and passed to the view before rendering.
*
* @return array
*/
protected function merge()
{
return array_merge(
$this->with(),
$this->view->getData(),
$this->override()
);
}
/**
* Data to be passed to view before rendering
*
* @return array
*/
protected function with()
{
return [];
}
/**
* Data to be passed to view before rendering
*
* @return array
*/
protected function override()
{
return static::$views;
}
$view = array_slice(explode('\\', static::class), 3);
$view = array_map([Str::class, 'snake'], $view, array_fill(0, count($view), '-'));
return implode('/', $view);
}
/**
* Compose the view before rendering.
*
* @param \Illuminate\View\View $view
* @return void
*/
public function compose(View $view)
{
$this->view = $view;
$this->data = new Fluent($view->getData());
$view->with($this->merge());
}
/**
* Data to be merged and passed to the view before rendering.
*
* @return array
*/
protected function merge()
{
return array_merge(
$this->with(),
$this->view->getData(),
$this->override()
);
}
/**
* Data to be passed to view before rendering
*
* @return array
return $callback;
}
/**
* Build a class based container callback Closure.
*
* @param string $class
* @param string $prefix
* @return \Closure
*/
protected function buildClassEventCallback($class, $prefix)
{
[$class, $method] = $this->parseClassEvent($class, $prefix);
// Once we have the class and method name, we can build the Closure to resolve
// the instance out of the IoC container and call the method on it with the
// given arguments that are passed to the Closure as the composer's data.
return function () use ($class, $method) {
return $this->container->make($class)->{$method}(...func_get_args());
};
}
/**
* Parse a class based composer name.
*
* @param string $class
* @param string $prefix
* @return array
*/
protected function parseClassEvent($class, $prefix)
{
return Str::parseCallback($class, $this->classEventMethodForPrefix($prefix));
}
/**
* Determine the class event method based on the given prefix.
*
* @param string $prefix
* @return string
* @param \Closure|string $listener
* @param bool $wildcard
* @return \Closure
*/
public function makeListener($listener, $wildcard = false)
{
if (is_string($listener)) {
return $this->createClassListener($listener, $wildcard);
}
if (is_array($listener) && isset($listener[0]) && is_string($listener[0])) {
return $this->createClassListener($listener, $wildcard);
}
return function ($event, $payload) use ($listener, $wildcard) {
if ($wildcard) {
return $listener($event, $payload);
}
return $listener(...array_values($payload));
};
}
/**
* Create a class based listener using the IoC container.
*
* @param string $listener
* @param bool $wildcard
* @return \Closure
*/
public function createClassListener($listener, $wildcard = false)
{
return function ($event, $payload) use ($listener, $wildcard) {
if ($wildcard) {
return call_user_func($this->createClassCallable($listener), $event, $payload);
}
$callable = $this->createClassCallable($listener);
return $callable(...array_values($payload));
* @param bool $halt
* @return array|null
*/
public function dispatch($event, $payload = [], $halt = false)
{
// When the given "event" is actually an object we will assume it is an event
// object and use the class as the event name and this event itself as the
// payload to the handler, which makes object based events quite simple.
[$event, $payload] = $this->parseEventAndPayload(
$event, $payload
);
if ($this->shouldBroadcast($payload)) {
$this->broadcastEvent($payload[0]);
}
$responses = [];
foreach ($this->getListeners($event) as $listener) {
$response = $listener($event, $payload);
// If a response is returned from the listener and event halting is enabled
// we will just return this response, and not call the rest of the event
// listeners. Otherwise we will add the response on the response list.
if ($halt && ! is_null($response)) {
return $response;
}
// If a boolean false is returned from a listener, we will stop propagating
// the event to any further listeners down in the chain, else we keep on
// looping through the listeners and firing every one in our sequence.
if ($response === false) {
break;
}
$responses[] = $response;
}
return $halt ? null : $responses;
}
protected function addEventListener($name, $callback)
{
if (Str::contains($name, '*')) {
$callback = function ($name, array $data) use ($callback) {
return $callback($data[0]);
};
}
$this->events->listen($name, $callback);
}
/**
* Call the composer for a given view.
*
* @param \Illuminate\Contracts\View\View $view
* @return void
*/
public function callComposer(ViewContract $view)
{
$this->events->dispatch('composing: '.$view->name(), [$view]);
}
/**
* Call the creator for a given view.
*
* @param \Illuminate\Contracts\View\View $view
* @return void
*/
public function callCreator(ViewContract $view)
{
$this->events->dispatch('creating: '.$view->name(), [$view]);
}
}
} catch (Throwable $e) {
$this->factory->flushState();
throw $e;
}
}
/**
* Get the contents of the view instance.
*
* @return string
*/
protected function renderContents()
{
// We will keep track of the amount of views being rendered so we can flush
// the section after the complete rendering operation is done. This will
// clear out the sections for any separate views that may be rendered.
$this->factory->incrementRender();
$this->factory->callComposer($this);
$contents = $this->getContents();
// Once we've finished rendering the view, we'll decrement the render count
// so that each sections get flushed out next time a view is created and
// no old sections are staying around in the memory of an environment.
$this->factory->decrementRender();
return $contents;
}
/**
* Get the evaluated contents of the view.
*
* @return string
*/
protected function getContents()
{
return $this->engine->get($this->path, $this->gatherData());
}
$this->view = $view;
$this->path = $path;
$this->engine = $engine;
$this->factory = $factory;
$this->data = $data instanceof Arrayable ? $data->toArray() : (array) $data;
}
/**
* Get the string contents of the view.
*
* @param callable|null $callback
* @return array|string
*
* @throws \Throwable
*/
public function render(callable $callback = null)
{
try {
$contents = $this->renderContents();
$response = isset($callback) ? $callback($this, $contents) : null;
// Once we have the contents of the view, we will flush the sections if we are
// done rendering all views so that there is nothing left hanging over when
// another view gets rendered in the future by the application developer.
$this->factory->flushStateIfDoneRendering();
return ! is_null($response) ? $response : $contents;
} catch (Throwable $e) {
$this->factory->flushState();
throw $e;
}
}
/**
* Get the contents of the view instance.
*
* @return string
<?php $__env->startSection('content'); ?>
<?php while(have_posts()): ?> <?php (the_post()); ?>
<?php echo $__env->first(['partials.content-single-' . get_post_type(), 'partials.content-single'], \Illuminate\Support\Arr::except(get_defined_vars(), ['__data', '__path']))->render(); ?>
<?php endwhile; ?>
<?php $__env->stopSection(); ?>
<?php echo $__env->make('layouts.app', \Illuminate\Support\Arr::except(get_defined_vars(), ['__data', '__path']))->render(); ?><?php /**PATH /home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/web/app/themes/tfs/resources/views/single.blade.php ENDPATH**/ ?>
/**
* Get the evaluated contents of the view at the given path.
*
* @param string $__path
* @param array $__data
* @return string
*/
protected function evaluatePath($__path, $__data)
{
$obLevel = ob_get_level();
ob_start();
extract($__data, EXTR_SKIP);
// We'll evaluate the contents of the view inside a try/catch block so we can
// flush out any stray output that might get out before an error occurs or
// an exception is thrown. This prevents any partial views from leaking.
try {
include $__path;
} catch (Throwable $e) {
$this->handleViewException($e, $obLevel);
}
return ltrim(ob_get_clean());
}
/**
* Handle a view exception.
*
* @param \Throwable $e
* @param int $obLevel
* @return void
*
* @throws \Throwable
*/
protected function handleViewException(Throwable $e, $obLevel)
{
while (ob_get_level() > $obLevel) {
ob_end_clean();
"/home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/web/app/themes/tfs/storage/framework/views/eb422c8beb3d93cfa2fe08ce3b438f23bc0fae21.php"
*
* @param string $path
* @param array $data
* @return string
*/
public function get($path, array $data = [])
{
$this->lastCompiled[] = $path;
// If this given view has expired, which means it has simply been edited since
// it was last compiled, we will re-compile the views so we can evaluate a
// fresh copy of the view. We'll pass the compiler the path of the view.
if ($this->compiler->isExpired($path)) {
$this->compiler->compile($path);
}
// Once we have the path to the compiled file, we will evaluate the paths with
// typical PHP just like any other templates. We also keep a stack of views
// which have been rendered for right exception messages to be generated.
$results = $this->evaluatePath($this->compiler->getCompiledPath($path), $data);
array_pop($this->lastCompiled);
return $results;
}
/**
* Handle a view exception.
*
* @param \Throwable $e
* @param int $obLevel
* @return void
*
* @throws \Throwable
*/
protected function handleViewException(Throwable $e, $obLevel)
{
$e = new ViewException($this->getMessage($e), 0, 1, $e->getFile(), $e->getLine(), $e);
parent::handleViewException($e, $obLevel);
$this->factory->callComposer($this);
$contents = $this->getContents();
// Once we've finished rendering the view, we'll decrement the render count
// so that each sections get flushed out next time a view is created and
// no old sections are staying around in the memory of an environment.
$this->factory->decrementRender();
return $contents;
}
/**
* Get the evaluated contents of the view.
*
* @return string
*/
protected function getContents()
{
return $this->engine->get($this->path, $this->gatherData());
}
/**
* Get the data bound to the view instance.
*
* @return array
*/
public function gatherData()
{
$data = array_merge($this->factory->getShared(), $this->data);
foreach ($data as $key => $value) {
if ($value instanceof Renderable) {
$data[$key] = $value->render();
}
}
return $data;
}
throw $e;
}
}
/**
* Get the contents of the view instance.
*
* @return string
*/
protected function renderContents()
{
// We will keep track of the amount of views being rendered so we can flush
// the section after the complete rendering operation is done. This will
// clear out the sections for any separate views that may be rendered.
$this->factory->incrementRender();
$this->factory->callComposer($this);
$contents = $this->getContents();
// Once we've finished rendering the view, we'll decrement the render count
// so that each sections get flushed out next time a view is created and
// no old sections are staying around in the memory of an environment.
$this->factory->decrementRender();
return $contents;
}
/**
* Get the evaluated contents of the view.
*
* @return string
*/
protected function getContents()
{
return $this->engine->get($this->path, $this->gatherData());
}
/**
$this->view = $view;
$this->path = $path;
$this->engine = $engine;
$this->factory = $factory;
$this->data = $data instanceof Arrayable ? $data->toArray() : (array) $data;
}
/**
* Get the string contents of the view.
*
* @param callable|null $callback
* @return array|string
*
* @throws \Throwable
*/
public function render(callable $callback = null)
{
try {
$contents = $this->renderContents();
$response = isset($callback) ? $callback($this, $contents) : null;
// Once we have the contents of the view, we will flush the sections if we are
// done rendering all views so that there is nothing left hanging over when
// another view gets rendered in the future by the application developer.
$this->factory->flushStateIfDoneRendering();
return ! is_null($response) ? $response : $contents;
} catch (Throwable $e) {
$this->factory->flushState();
throw $e;
}
}
/**
* Get the contents of the view instance.
*
* @return string
<!doctype html>
<html <?php language_attributes(); ?>>
<?php echo \Roots\view(\Roots\app('sage.view'), \Roots\app('sage.data'))->render(); ?>
</html>
}
break;
}
}
if ( ! $template ) {
$template = get_index_template();
}
/**
* Filters the path of the current template before including it.
*
* @since 3.0.0
*
* @param string $template The path of the template to include.
*/
$template = apply_filters( 'template_include', $template );
if ( $template ) {
include $template;
} elseif ( current_user_can( 'switch_themes' ) ) {
$theme = wp_get_theme();
if ( $theme->errors() ) {
wp_die( $theme->errors() );
}
}
return;
}
"/home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/web/app/themes/tfs/index.php"
<?php
/**
* Loads the WordPress environment and template.
*
* @package WordPress
*/
if ( ! isset( $wp_did_header ) ) {
$wp_did_header = true;
// Load the WordPress library.
require_once __DIR__ . '/wp-load.php';
// Set up the WordPress query.
wp();
// Load the theme template.
require_once ABSPATH . WPINC . '/template-loader.php';
}
"/home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/web/wp/wp-includes/template-loader.php"
<?php
/**
* WordPress View Bootstrapper
*/
define('WP_USE_THEMES', true);
require __DIR__ . '/wp/wp-blog-header.php';
"/home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/web/wp/wp-blog-header.php"
Key | Value |
query_vars | array:3 [ "page" => "" "name" => "jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage" "category_name" => "blog" ] |
query_string | "name=jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage&category_name=blog"
|
request | "blog/jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage"
|
matched_rule | "(.+?)/([^/]+)(?:/([0-9]+))?/?$"
|
matched_query | "category_name=blog&name=jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage&page="
|
did_permalink | true
|
Key | Value |
query | array:3 [ "page" => "" "name" => "jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage" "category_name" => "blog" ] |
query_vars | array:66 [ "page" => 0 "name" => "jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage" "category_name" => "blog" "error" => "" "m" => "" "p" => 0 "post_parent" => "" "subpost" => "" "subpost_id" => "" "attachment" => "" "attachment_id" => 0 "pagename" => "" "page_id" => 0 "second" => "" "minute" => "" "hour" => "" "day" => 0 "monthnum" => 0 "year" => 0 "w" => 0 "tag" => "" "cat" => "" "tag_id" => "" "author" => "" "author_name" => "" "feed" => "" "tb" => "" "paged" => 0 "meta_key" => "" "meta_value" => "" "preview" => "" "s" => "" "sentence" => "" "title" => "" "fields" => "" "menu_order" => "" "embed" => "" "category__in" => [] "category__not_in" => [] "category__and" => [] "post__in" => [] "post__not_in" => [] "post_name__in" => [] "tag__in" => [] "tag__not_in" => [] "tag__and" => [] "tag_slug__in" => [] "tag_slug__and" => [] "post_parent__in" => [] "post_parent__not_in" => [] "author__in" => [] "author__not_in" => [] "search_columns" => [] "ignore_sticky_posts" => false "suppress_filters" => false "cache_results" => true "update_post_term_cache" => true "update_menu_item_cache" => false "lazy_load_term_meta" => true "update_post_meta_cache" => true "post_type" => "" "posts_per_page" => 10 "nopaging" => false "comments_per_page" => "50" "no_found_rows" => false "order" => "DESC" ] |
meta_query | WP_Meta_Query {#2559} |
queried_object | WP_Post {#2560} |
queried_object_id | 21808
|
request | """ SELECT wp_posts.*\n \t\t\t\t\t FROM wp_posts \n \t\t\t\t\t WHERE 1=1 AND wp_posts.post_name = 'jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage' AND wp_posts.post_type = 'post'\n \t\t\t\t\t \n \t\t\t\t\t ORDER BY wp_posts.post_date DESC\n \t\t\t\t\t """ |
post_count | 1
|
in_the_loop | true
|
current_comment | -1
|
found_posts | 1
|
is_single | true
|
is_singular | true
|
Key | Value |
ID | 21808
|
post_author | "43"
|
post_date | "2020-12-15 20:02:31"
|
post_date_gmt | "2020-12-15 20:02:31"
|
post_content | """ The 2020 Toronto Film School Festival of Films went virtual this year.\n \n \n \n The annual showcase took place during an all-day, online screening on Thursday, Dec. 3 – and featured the best short films, documentaries, commercials and music videos created by Toronto Film School students and graduates.\n \n \n \n <a href="https://www.torontofilmschool.ca/programs/film-production-diploma/faculty/" target="_blank" rel="noopener noreferrer">Yale Massey</a>, Director of the <a href="https://www.torontofilmschool.ca/programs/film-production-diploma/" target="_blank" rel="noopener noreferrer">Film Production</a> Program, applauded each and every one of those students who played a part in bringing this year’s amazing lineup of 64 projects to the screen – from the directors and actors, to the crew members and post-production.\n \n \n \n <img class="alignnone size-medium wp-image-21733 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_ALL_FestivalOfFilms_Yale_1203.jpg" alt="" width="670" height="393" />\n \n \n \n “Congratulations to all the filmmakers involved in the festival, all the crew, every single one of you – it doesn’t matter what you did, if you participated on any of these films, sit back, relax and enjoy this screening,” he told viewers at the beginning of the eight-hour event.\n \n \n \n In total, this year’s Toronto Film School Festival of Films saw the screening of 10 commercials and public service announcements, 14 music videos, 13 documentaries, and 27 short films.\n \n \n \n Toronto Film School’s <a href="https://www.torontofilmschool.ca/blog/andrew-barnsley-celebrates-schitts-creeks-historic-night-at-emmys/">Emmy-winning</a> <a href="https://www.torontofilmschool.ca/blog/andrew-barnsley-executive-producer-schitts-creek-joins-toronto-film-school-executive-producer-residence/">Executive Producer in Residence</a>, <a href="http://www.project10.ca/about">Andrew Barnsley</a> was on hand to announce the nominees in 16 different award categories.\n \n \n \n <img class="alignnone size-medium wp-image-21734 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_ALL_AndrewBarnsleyFestivalOfFilms_1203.jpg" alt="" width="670" height="393" />\n \n \n \n "What a day of screening it’s been watching all the talent that has come out of the Toronto Film School classrooms and sets. It makes me very proud to watch these and see the level that you’re all working at,” he said before announcing the 2020 nominees.\n \n \n \n “It truly is an honour to be nominated and this year’s class of nominees is really quite impressive.”\n \n \n <p style="text-align: center;">The nominees for the 2020 Toronto Film School Festival of Films nominations are:</p>\n \n <p style="text-align: center;"><strong>Best Picture:</strong></p>\n <p style="text-align: center;"> <em>The Adjustment</em></p>\n <p style="text-align: center;"><em>Red Underwear</em></p>\n <p style="text-align: center;"><em>My Special Date</em></p>\n <p style="text-align: center;"><em>Insomniac Idiot</em></p>\n <p style="text-align: center;"><em>Vitamin</em></p>\n <p style="text-align: center;"><em>The Burning Cold</em></p>\n \n \n <img class="alignnone size-medium wp-image-21742 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_FestOfFilmTheAdjustment_1203.jpg" alt="" width="670" height="393" />\n <p style="text-align: center;"><strong> </strong><strong> </strong></p>\n <p style="text-align: center;"><strong>Best Director:</strong></p>\n <p style="text-align: center;"> <em>Red Underwear </em>| Jamyang Kunga Tenzin</p>\n <p style="text-align: center;"><em>The Adjustment </em>| Talia Faubert</p>\n <p style="text-align: center;"><em>My Special Date </em>| Ayush Anand</p>\n <p style="text-align: center;"><em>Vitamin </em>| Natalia Aranguren & Yeimy Daza</p>\n <p style="text-align: center;"><em>The Burning Cold </em>| Naser Vafi</p>\n <p style="text-align: center;"><strong> </strong><strong> </strong></p>\n <p style="text-align: center;"><strong>Best Producer:</strong></p>\n <p style="text-align: center;"> <em>CODA </em>| Isabela Popolizio</p>\n <p style="text-align: center;"><em>Last Man </em>| Igor Trushin</p>\n <p style="text-align: center;"><em>My Special Date </em>| Jamyang Kunga Tenzin</p>\n <p style="text-align: center;"><em>Red Underwear </em>| Alam Loyo & Jamyang Kunga Tenzin</p>\n <p style="text-align: center;"><em>The Adjustment </em>| Talia Faubert</p>\n \n \n <img class="alignnone size-medium wp-image-21743 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_FestOfFilmsRedUnderwear_1203.jpg" alt="" width="670" height="393" />\n <p style="text-align: center;"><strong> </strong><strong> </strong></p>\n <p style="text-align: center;"><strong>Best Female Performance:</strong></p>\n <p style="text-align: center;">Natalia Aranguren |<em>Vitamin</em></p>\n <p style="text-align: center;">Alex Nicolescu | <em>Begin Again</em></p>\n <p style="text-align: center;">Sani Jalalzadeh | <em>The Burning Cold</em></p>\n <p style="text-align: center;">Mary Kwarteng | <em>Third Scar</em></p>\n <p style="text-align: center;">Heather Headley | <em>The Adjustment</em></p>\n <p style="text-align: center;"><strong> </strong><strong> </strong></p>\n <p style="text-align: center;"><strong>Best Male Performance:</strong></p>\n <p style="text-align: center;"> Joseph Dancey | <em>Begin Again</em></p>\n <p style="text-align: center;">Michael Abram | <em>Nice Guy</em></p>\n <p style="text-align: center;">Jamyang Kunga Tenzin | <em>Red Underwear</em></p>\n <p style="text-align: center;">Kiran Yashwanth | <em>The Envelope</em></p>\n <p style="text-align: center;">Niko Combitsis | <em>The Adjustment</em></p>\n \n \n <img class="alignnone size-medium wp-image-21744 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_FestOfFilmsMySpecialDate_1203.jpg" alt="" width="670" height="393" />\n \n \n <p style="text-align: center;"><strong>Best Screenplay:</strong></p>\n <p style="text-align: center;"> <em>Insomniac Idiot</em> | David Garcia Delgadillo</p>\n <p style="text-align: center;"><em>Vitamin</em> | <em>Natalia Aranguren, Mario Alberto Aranguren & Yeimy Daza</em></p>\n <p style="text-align: center;"><em>The Adjustment</em> | Talia Faubert</p>\n <p style="text-align: center;"><em>Begin Again</em> | Alex Nicolescu</p>\n <p style="text-align: center;"><em>Red Underwear</em> | Jamyang Kunga Tenzin</p>\n <p style="text-align: center;"><em>The Burning Cold</em> | Naser Vafi</p>\n <p style="text-align: center;"><strong><em> </em></strong></p>\n <p style="text-align: center;"><strong> </strong><strong>Best Cinematography:</strong></p>\n <p style="text-align: center;"> <em>All for You</em></p>\n <p style="text-align: center;"><em>The Adjustment</em></p>\n <p style="text-align: center;"><em>Red Underwear</em></p>\n <p style="text-align: center;"><em>My Special Date</em></p>\n <p style="text-align: center;"><em>Heavy Footed</em></p>\n \n \n <img class="alignnone size-medium wp-image-21745 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_FestOfFilmsInsomniacIdiot_1203.jpg" alt="" width="670" height="393" />\n <p style="text-align: center;"><strong> </strong></p>\n <p style="text-align: center;"><strong> </strong><strong>Best Documentary:</strong></p>\n <p style="text-align: center;"> <em>A Few From the Top</em> | Ian Christison</p>\n <p style="text-align: center;"><em>Gezi Park Protests</em> | Ece Gokcek</p>\n <p style="text-align: center;"><em>Mothering in Quarantine</em> | Kyisha Williams</p>\n <p style="text-align: center;"><em>Forget Me Not</em> | Camille Allaire</p>\n <p style="text-align: center;"><em>Impetuous</em> | Fen John Kanichukkattu</p>\n <p style="text-align: center;"><em>Till the End</em> | Jakob Pansieri</p>\n <p style="text-align: center;"><em>Stories from Sparrow Lake</em> | Valerie Stanton</p>\n <p style="text-align: center;"><em>Jamie Got Ghosted</em> | Jamie Norrie</p>\n <p style="text-align: center;"><strong> </strong></p>\n <p style="text-align: center;"><strong> </strong><strong>Best Sound:</strong></p>\n <p style="text-align: center;"> <em>Heavy Footed</em></p>\n <p style="text-align: center;"><em>Vitamin</em></p>\n <p style="text-align: center;"><em>Sonambulo (Sleepwalker)</em></p>\n <p style="text-align: center;"><em>The Envelope</em></p>\n <p style="text-align: center;"><em>CODA</em></p>\n \n \n <img class="alignnone size-medium wp-image-21746 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_FestOfFilmsVitamin_1203.jpg" alt="" width="670" height="393" />\n <p style="text-align: center;"><strong> </strong></p>\n <p style="text-align: center;"><strong> </strong><strong>Best Visual Effects:</strong></p>\n <p style="text-align: center;"> <em>All For You</em></p>\n <p style="text-align: center;"><em>Life & Death</em></p>\n <p style="text-align: center;"><em>Waiting Room</em></p>\n <p style="text-align: center;"><em>Red Underwear</em></p>\n <p style="text-align: center;"><em>Sonambulo (Sleepwalker)</em></p>\n <p style="text-align: center;"><strong> </strong></p>\n <p style="text-align: center;"><strong> </strong><strong>Best Film Editing:</strong></p>\n <p style="text-align: center;"> <em>The Adjustment</em></p>\n <p style="text-align: center;"><em>Sonambulo (Sleepwalker)</em></p>\n <p style="text-align: center;"><em>The Envelope</em></p>\n <p style="text-align: center;"><em>My Special Date</em></p>\n <p style="text-align: center;"><em>Red Underwear</em></p>\n \n \n <img class="alignnone size-medium wp-image-21747 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_FestOfFilmsTheBurningGold_1203.jpg" alt="" width="670" height="393" />\n <p style="text-align: center;"><strong> </strong></p>\n <p style="text-align: center;"><strong> </strong><strong>Best Production Design:</strong></p>\n <p style="text-align: center;"> <em>Red Underwear</em></p>\n <p style="text-align: center;"><em>Heavy Footed</em></p>\n <p style="text-align: center;"><em>Vitamin</em></p>\n <p style="text-align: center;"><em>CODA</em></p>\n <p style="text-align: center;"><em>Lyrics</em></p>\n <p style="text-align: center;"><strong> </strong></p>\n <p style="text-align: center;"><strong>Best Commercial:</strong></p>\n <p style="text-align: center;"><em>Casper </em>| Mario Aguilera</p>\n <p style="text-align: center;"> <em>End of the Rope</em> | Pulkit Mehndiratta</p>\n <p style="text-align: center;"><em>Remember Living</em> | Noel Pendawa</p>\n <p style="text-align: center;"><em>Cheerios</em> | Pulkit Mehndiratta</p>\n <p style="text-align: center;"><em>Heineken</em> | Yi Zhang (Leo)</p>\n \n \n <img class="alignnone size-medium wp-image-21749 aligncenter" src="https://dev.tfs.staging.poundandgrain.ca/app/uploads/2020/12/TFS_FestOfFilmsAllForYouMusicVideo_1203.jpg" alt="" width="451" height="526" />\n \n \n <p style="text-align: center;"><strong>Best Music Video:</strong></p>\n <p style="text-align: center;"><em>All For You</em> | Simeon Ross</p>\n <p style="text-align: center;"><em>Black Grrl Magik</em> | Kyisha Williams and Fonna Seidu</p>\n <p style="text-align: center;"><em>Heading Home</em> | Jeremy Vandenhelm</p>\n <p style="text-align: center;"><em>Bye</em> | Kendal Straughn</p>\n <p style="text-align: center;"><em>Waiting Room |</em><em> </em>Noel Pendawa</p>\n <p style="text-align: center;"><em>5 In The Morning</em> | Jamie Norrie</p>\n <p style="text-align: center;"><em>Stop Trying to be God</em> | Ahmed El Gabbour (Basko) & Stephanie Chaisson</p>\n <p style="text-align: center;"><strong> </strong></p>\n <p style="text-align: center;"><strong> </strong><strong>Motion Design Award:</strong></p>\n <p style="text-align: center;">Abigail Thorson</p>\n <p style="text-align: center;">Dhara Leuva</p>\n <p style="text-align: center;">Rachel Boudreau Richard</p>\n <p style="text-align: center;">Alifyah Doraib Kisat</p>\n <p style="text-align: center;">Angela Chulkova</p>\n <p style="text-align: center;">Rebecca Jaek</p>\n <p style="text-align: center;"><strong> </strong></p>\n <p style="text-align: center;"><strong> </strong><strong>Best Graduating Video Game:</strong></p>\n <p style="text-align: center;"> <em>Litany of the Cursed</em> | Summer 2019</p>\n <p style="text-align: center;"><em>A Lynx’s Tale</em> | Fall 2019</p>\n <p style="text-align: center;"><em>Ironlight</em> | Winter 2020</p>\n <p style="text-align: center;"><em>Kaiju Bash</em> | Winter 2020</p>\n <p style="text-align: center;"><em>Catavaneer</em> | Spring 2020</p>\n <p style="text-align: center;"><em>Junkin’ Drivers</em> | Spring 2020</p>\n \n <p style="text-align: center;"><strong>The winners will be announced on Saturday, Feb. 27 at 7 p.m. </strong></p> """ |
post_title | "Jack Grinhaus Brings 'Wings of Hope' to the TFS Virtual Stage"
|
post_excerpt | "" |
post_status | "publish"
|
comment_status | "closed"
|
ping_status | "open"
|
post_password | "" |
post_name | "jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage"
|
to_ping | "" |
pinged | "" |
post_modified | "2023-03-27 21:07:43"
|
post_modified_gmt | "2023-03-27 21:07:43"
|
post_content_filtered | "" |
post_parent | 0
|
guid | "https://dev.tfs.staging.poundandgrain.ca/?p=21808"
|
menu_order | 0
|
post_type | "post"
|
post_mime_type | "" |
comment_count | "0"
|
filter | "raw"
|
Key | Value |
SERVER_SOFTWARE | "nginx/1.22.1"
|
REQUEST_URI | "/blog/jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage/"
|
USER | "forge"
|
HOME | "/home/forge"
|
HTTP_REFERER | "https://dev.tfs.staging.poundandgrain.ca/blog/jack-grinhaus-brings-wings-of-hope-to-the-tfs-virtual-stage"
|
HTTP_ACCEPT_ENCODING | "gzip, br, zstd, deflate"
|
HTTP_USER_AGENT | "Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)"
|
HTTP_ACCEPT | "*/*"
|
HTTP_HOST | "dev.tfs.staging.poundandgrain.ca"
|
REDIRECT_STATUS | "200"
|
HTTPS | "on"
|
SERVER_NAME | "dev.tfs.staging.poundandgrain.ca"
|
SERVER_PORT | "443"
|
SERVER_ADDR | "10.0.1.187"
|
REMOTE_PORT | "34750"
|
REMOTE_ADDR | "3.141.193.126"
|
GATEWAY_INTERFACE | "CGI/1.1"
|
SERVER_PROTOCOL | "HTTP/2.0"
|
DOCUMENT_ROOT | "/home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/web"
|
DOCUMENT_URI | "/index.php"
|
SCRIPT_NAME | "/index.php"
|
SCRIPT_FILENAME | "/home/forge/dev.tfs.staging.poundandgrain.ca/releases/20241113033749/web/index.php"
|
CONTENT_LENGTH | "" |
CONTENT_TYPE | "" |
REQUEST_METHOD | "GET"
|
QUERY_STRING | "" |
FCGI_ROLE | "RESPONDER"
|
PHP_SELF | "/index.php"
|
REQUEST_TIME_FLOAT | 1731849952.3693
|
REQUEST_TIME | 1731849952
|
DB_NAME | "tfs_dev"
|
DB_USER | "***"
|
DB_PASSWORD | "************"
|
WP_ENV | "development"
|
WP_HOME | "https://dev.tfs.staging.poundandgrain.ca"
|
WP_SITEURL | "https://dev.tfs.staging.poundandgrain.ca/wp"
|
WP_DEBUG_LOG | "/path/to/debug.log"
|
AUTH_KEY | "****************************************************************"
|
SECURE_AUTH_KEY | "****************************************************************"
|
LOGGED_IN_KEY | "****************************************************************"
|
NONCE_KEY | "****************************************************************"
|
AUTH_SALT | "****************************************************************"
|
SECURE_AUTH_SALT | "****************************************************************"
|
LOGGED_IN_SALT | "****************************************************************"
|
NONCE_SALT | "****************************************************************"
|
ACF_PRO_KEY | "b3JkZXJfaWQ9NDQxMjV8dHlwZT1kZXZlbG9wZXJ8ZGF0ZT0yMDE0LTExLTEyIDA2OjA0OjE3"
|
Key | Value |
DB_NAME | "tfs_dev"
|
DB_USER | "***"
|
DB_PASSWORD | "************"
|
WP_ENV | "development"
|
WP_HOME | "https://dev.tfs.staging.poundandgrain.ca"
|
WP_SITEURL | "https://dev.tfs.staging.poundandgrain.ca/wp"
|
WP_DEBUG_LOG | "/path/to/debug.log"
|
AUTH_KEY | "****************************************************************"
|
SECURE_AUTH_KEY | "****************************************************************"
|
LOGGED_IN_KEY | "****************************************************************"
|
NONCE_KEY | "****************************************************************"
|
AUTH_SALT | "****************************************************************"
|
SECURE_AUTH_SALT | "****************************************************************"
|
LOGGED_IN_SALT | "****************************************************************"
|
NONCE_SALT | "****************************************************************"
|
ACF_PRO_KEY | "b3JkZXJfaWQ9NDQxMjV8dHlwZT1kZXZlbG9wZXJ8ZGF0ZT0yMDE0LTExLTEyIDA2OjA0OjE3"
|