*
* @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/uat.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/uat.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/uat.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/uat.tfs.staging.poundandgrain.ca/releases/20241113033749/web/app/themes/tfs/storage/framework/views/2bc8d2ea874031e3ddb3a557319b7cad31a2f2d3.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/uat.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/uat.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/uat.tfs.staging.poundandgrain.ca/releases/20241113033749/web/wp/wp-blog-header.php"
Key | Value |
query_vars | array:3 [ "page" => "" "name" => "tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry" "category_name" => "blog" ] |
query_string | "name=tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry&category_name=blog"
|
request | "blog/tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry"
|
matched_rule | "(.+?)/([^/]+)(?:/([0-9]+))?/?$"
|
matched_query | "category_name=blog&name=tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry&page="
|
did_permalink | true
|
Key | Value |
query | array:3 [ "page" => "" "name" => "tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry" "category_name" => "blog" ] |
query_vars | array:66 [ "page" => 0 "name" => "tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry" "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" => 16 "nopaging" => false "comments_per_page" => "50" "no_found_rows" => false "order" => "DESC" ] |
meta_query | WP_Meta_Query {#2562} |
queried_object | WP_Post {#2563} |
queried_object_id | 25194
|
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 = 'tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry' 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 | 25194
|
post_author | "43"
|
post_date | "2022-04-04 18:45:32"
|
post_date_gmt | "2022-04-04 18:45:32"
|
post_content | """ <p style="font-weight: 400;">The City of Toronto recently released its <a tabindex="-1" title="https://www.toronto.ca/news/torontos-screen-production-industry-sets-record-with-more-than-2-5-billion-in-direct-spending-in-2021/" href="https://www.toronto.ca/news/torontos-screen-production-industry-sets-record-with-more-than-2-5-billion-in-direct-spending-in-2021/" target="_blank" rel="noopener noreferrer" aria-label="Link 2021 report card">2021 report card</a> on the state of the local screen production industry and the results were “historically” good – especially for Toronto Film School grads looking to make their mark.</p>\n \n <p style="font-weight: 400;">In total, more than $2.5 billion in direct spending was invested in the city’s film, television and digital media productions in 2021, and Toronto’s screen production industry is poised to experience even more rapid growth and momentum in the year to come.</p>\n \n \n [caption id="attachment_17983" align="aligncenter" width="670"]<img class="wp-image-17983 size-medium" src="https://uat.tfs.staging.poundandgrain.ca/app/uploads/2023/03/TFS_ALL_Tory460Camera_1106-670x393-1.jpg" alt="Toronto Mayor at Toronto Film School" width="670" height="393" /> Mayor John Tory toured Toronto Film School's 460 Yonge Street campus in 2019.[/caption]\n \n \n <p style="font-weight: 400;">Toronto Mayor John Tory touted the continuing expansion of the city’s screen industry – which is already one of the largest in North America – as “a huge achievement and testament to the strength of the sector.”</p>\n \n <p style="font-weight: 400;">“We have seen expansive growth and jobs over the past few years, and along with the continued investments we have made in the infrastructure and workforce, I am confident that the growth will continue for years ahead,” Tory said in a statement.</p>\n \n <p style="font-weight: 400;">“I want to thank all of our partners for helping us create a world-class industry that continues to garner the interest of global players and companies.”</p>\n \n <p style="font-weight: 400;">In a year that saw Toronto host 1,468 productions over the course of 7,800 production days, Tory singled out several of the “key productions” that helped Toronto’s screen industry workforce grow to more than 35,000 people.</p>\n \n <p style="font-weight: 400;">Included among those productions were <a href="https://www.imdb.com/title/tt7740496/" target="_blank" rel="noopener noreferrer"><em>Nightmare Alley</em></a>, <a href="https://www.imdb.com/title/tt7949218/?ref_=fn_al_tt_1" target="_blank" rel="noopener noreferrer"><em>See</em></a><em>, </em><a href="https://www.imdb.com/title/tt9288030/?ref_=fn_al_tt_1" target="_blank" rel="noopener noreferrer"><em>Reacher</em></a><em>, </em><a href="https://www.imdb.com/title/tt1043813/?ref_=nv_sr_srsg_0" target="_blank" rel="noopener noreferrer"><em>Titans</em></a><em>, </em><a href="https://www.imdb.com/title/tt5171438/?ref_=fn_al_tt_1" target="_blank" rel="noopener noreferrer"><em>Star Trek: Discovery</em></a><em>, </em><a href="https://www.imdb.com/title/tt3007572/?ref_=nv_sr_srsg_0" target="_blank" rel="noopener noreferrer"><em>Locke & Key</em></a>, <em>and</em> <a href="https://www.imdb.com/title/tt8388390/?ref_=nv_sr_srsg_0" target="_blank" rel="noopener noreferrer"><em>Chucky</em></a> – on each of whose sets Toronto Film School was represented by alumni and faculty working in their respective fields.</p>\n \n <p style="font-weight: 400;">Several of those TFS community members took time to share their first-hand experiences working here in Toronto during a record-setting year in the industry. Here’s what they had to say:</p>\n \n \n [caption id="attachment_25196" align="aligncenter" width="670"]<img class="wp-image-25196 size-medium" src="https://uat.tfs.staging.poundandgrain.ca/app/uploads/2023/03/TFS_FP_MousaGhodratifard_See_0330-670x458-1.jpg" alt="Assistant Director Mousa Ghodratifard and Apple TV series, See poster" width="670" height="458" /> Film Production grad Mousa Ghodratifard worked as an Assistant Director on the hit Apple TV series, See.[/caption]\n \n \n <p style="font-weight: 400;"><a href="https://www.imdb.com/name/nm5730287/?ref_=nv_sr_srsg_0" target="_blank" rel="noopener noreferrer">Mousa Ghodratifard</a>, a Class of 2013 <a href="https://staging.torontofilmschool.ca/programs/film-production-diploma/" target="_blank" rel="noopener noreferrer">Film Production</a> graduate, worked as an Assistant Director on the second and third seasons of <a href="https://www.imdb.com/name/nm0597388/?ref_=ttfc_fc_cl_t1" target="_blank" rel="noopener noreferrer">Jason Momoa</a> and <a href="https://www.imdb.com/name/nm0005569/?ref_=ttfc_fc_cl_t7" target="_blank" rel="noopener noreferrer">Alfre Woodard</a>’s hit Apple TV series,<a href="https://www.imdb.com/title/tt7949218/fullcredits?ref_=tt_ov_st_sm" target="_blank" rel="noopener noreferrer"> <em>See</em></a>. Created by <a href="https://www.imdb.com/name/nm1140275/?ref_=tt_ov_wr" target="_blank" rel="noopener noreferrer">Steven Knight</a>, the sci-fi drama is set in a dystopian future in which the human race has lost its sense of sight, and society has had to find new ways to interact, build, hunt, and to survive.</p>\n \n <p style="font-weight: 400;">“Working on <em>See</em> gives me the opportunity to know and work with the number one experienced film crew in Canada – from designers to shooting crew, creators and casts,” Ghodratifard said.</p>\n \n <p style="font-weight: 400;">“Being an assistant director on the biggest budgeted TV show filmed in Ontario also gave me a chance to learn how time is important and how you can manage that in the pre-production by working closely with every department.”</p>\n \n <p style="font-weight: 400;">In his role, Ghodratifard said he was given the opportunity to work closely with the show’s director of photography to manage the large number of background performers and extras required to fill some of the blockbuster’s frames.</p>\n \n <p style="font-weight: 400;">“Studying at Toronto Film School has helped me to know about all aspects of filmmaking, such as scheduling the filming, understanding the scenes and scripts, and how to work with talent,” he said. “My biggest takeaway from working on <em>See</em> was becoming a stronger AD and learning from the best-of-the-best film crew.”</p>\n \n \n [caption id="attachment_25197" align="aligncenter" width="670"]<img class="wp-image-25197 size-medium" src="https://uat.tfs.staging.poundandgrain.ca/app/uploads/2023/03/TFS_FP_DrewMoss_Reacher_0330-670x458-1.jpg" alt="Film Production alumnus Drew Moss plays Pete Jobling Jr. in the Amazon Original, Reacher" width="670" height="458" /> Drew Moss, a Film Production alumnus, was cast as Pete Jobling Jr. in the Amazon Original, Reacher.[/caption]\n \n \n <p style="font-weight: 400;">Class of 2005 <a href="https://staging.torontofilmschool.ca/programs/film-production-diploma/" target="_blank" rel="noopener noreferrer">Film Production</a> alumnus <a href="https://www.imdb.com/name/nm4373436/?ref_=fn_al_nm_1" target="_blank" rel="noopener noreferrer">Drew Moss</a> was cast in the role of Pete Jobling Jr. in the Amazon Original, <a href="https://www.imdb.com/title/tt9288030/?ref_=nm_knf_i1" target="_blank" rel="noopener noreferrer"><em>Reacher</em></a><em>. </em>Based on the <em>Jack Reacher</em> book series by <a href="https://en.wikipedia.org/wiki/Lee_Child" target="_blank" rel="noopener noreferrer">Lee Child</a>, it stars <a href="https://en.wikipedia.org/wiki/Alan_Ritchson" target="_blank" rel="noopener noreferrer">Alan Ritchson</a> as the title character – a drifter and former military policeman who battles dangerous criminals throughout his travels.</p>\n \n <p style="font-weight: 400;">“Working on one of the biggest budget productions in Ontario was a fantastic experience. I got to work with such a talented cast and crew. The stunt team was fantastic, and I appreciate all of their hard work during my stunt scenes,” Moss said.</p>\n \n <p style="font-weight: 400;">“My experience at TFS helped me grasp the tasks and demands needed to perform at the most professional level on set. Although the road is tough to follow your dreams, the reward of being able to express yourself artistically is life-changing. It is my therapy.”</p>\n \n \n [caption id="attachment_25239" align="aligncenter" width="650"]<img class="wp-image-25239 size-full" src="https://uat.tfs.staging.poundandgrain.ca/app/uploads/2022/04/TFS_ACT_TrevorBelanger_MayorOfKingstown_0331.jpg" alt="" width="650" height="450" /> Acting grad Garima Sood worked as a camera trainee on the set of Chucky.[/caption]\n \n \n <p style="font-weight: 400;"><a href="https://www.imdb.com/name/nm11501106/?ref_=nv_sr_srsg_0" target="_blank" rel="noopener noreferrer">Garima Sood</a>, who graduated from the <a href="https://staging.torontofilmschool.ca/programs/acting-for-film-tv-and-the-theatre-diploma/" target="_blank" rel="noopener noreferrer">Acting for Film, TV & the Theatre</a> program in 2018, worked as a camera trainee on the set of <em><a href="https://www.imdb.com/title/tt8388390/?ref_=fn_al_tt_1" target="_blank" rel="noopener noreferrer">Chucky</a></em><em>, </em>a Syfy/USA Network horror series based on the <em><a href="https://en.wikipedia.org/wiki/Child%27s_Play_(franchise)" target="_blank" rel="noopener noreferrer">Child’s Play</a></em> film franchise.</p>\n <p style="font-weight: 400;">“Working on <em>Chucky</em> was a blast! The camera team, the producer, the cast, and the whole crew were a delight to work with,” she said.</p>\n <p style="font-weight: 400;">“It was a big project that was heavy on VFX and puppeteer movements. It was very interesting to see the intricacies of how it all works to make the real doll come alive! I’ll always cherish the moments from <em>Chucky</em>, especially with the camera crew.”</p>\n \n \n \n \n [caption id="attachment_25198" align="aligncenter" width="670"]<img class="wp-image-25198 size-medium" src="https://uat.tfs.staging.poundandgrain.ca/app/uploads/2023/03/TFS_ACT_KimJanveau_NightmareAlley_0330-670x458-1.jpg" alt="Acting for Film, TV and Theatre grad Kim Janveau in Nightmare Alley." width="670" height="458" /> Acting for Film, TV &; the Theatre grad Kim Janveau was cast as a carnival patron in the Oscar-nominated film Nightmare Alley.[/caption]\n \n \n <p style="font-weight: 400;"><a href="https://www.imdb.com/name/nm10674871/?ref_=fn_al_nm_1" target="_blank" rel="noopener noreferrer">Kim Janveau</a>, who graduated from the <a href="https://staging.torontofilmschool.ca/programs/acting-for-film-tv-and-the-theatre-diploma/" target="_blank" rel="noopener noreferrer">Acting for Film, TV & the Theatre</a> program in 2019, was cast as an Ambrose Carnival Patron in <a href="https://www.imdb.com/title/tt7740496/" target="_blank" rel="noopener noreferrer"><em>Nightmare Alley</em></a>. The Oscar-nominated crime thriller, which was directed by <a href="https://www.imdb.com/name/nm0868219/?ref_=tt_ov_dr" target="_blank" rel="noopener noreferrer">Guillermo del Toro</a>, tells the story of a grifter (<a href="https://en.wikipedia.org/wiki/Bradley_Cooper" target="_blank" rel="noopener noreferrer">Bradley Cooper</a>) working his way up from low-ranking carnival worker to lauded psychic medium.</p>\n \n <p style="font-weight: 400;">“The production was huge, with many, many people in all departments, and many built sets within close proximity that were immersive,” Janveau said of her experience as an extra on the set.</p>\n \n <p style="font-weight: 400;">“Preparing for this experience, TFS and other productions have taught me how in-film change will be inevitable and constant, no matter what, and you need to be ready to adapt to it all, especially with an open mind. Make sure you know what you are doing, where you are going and if you are not sure, use your words and ASK someone.”</p>\n \n <p style="font-weight: 400;">Other TFS community members who worked on some of the “key” big-budget productions in Toronto in 2021 included:</p>\n \n <ul>\n \t<li><a href="https://www.imdb.com/name/nm9318682/" target="_blank" rel="noopener noreferrer">Laura Loaiza</a> (<a href="https://staging.torontofilmschool.ca/programs/film-production-diploma/" target="_blank" rel="noopener noreferrer">Film Production</a> '17) worked as a Camera Trainee on the set of <a href="https://www.imdb.com/title/tt7740496/" target="_blank" rel="noopener noreferrer"><em>Nightmare Alley</em></a></li>\n \t<li><a href="https://www.imdb.com/name/nm10167628/?ref_=fn_al_nm_1" target="_blank" rel="noopener noreferrer">Alexander Melvin</a> (<a href="https://staging.torontofilmschool.ca/programs/graphic-design-interactive-media-diploma/" target="_blank" rel="noopener noreferrer">Graphic Design & Interactive Media</a> '15) worked as a Motion Graphic Designer on the sets of both <em><a href="https://www.imdb.com/title/tt5171438/?ref_=nm_flmg_ardp_1" target="_blank" rel="noopener noreferrer">Star Trek: Discovery</a> </em>and <em><a href="https://www.imdb.com/title/tt3007572/?ref_=nv_sr_srsg_0" target="_blank" rel="noopener noreferrer">Locke & Key</a></em></li>\n \t<li><a href="https://www.imdb.com/name/nm0600436/?ref_=fn_al_nm_1" target="_blank" rel="noopener noreferrer">Andrew Moodie</a> (<a href="https://staging.torontofilmschool.ca/programs/acting-for-film-tv-and-the-theatre-diploma/" target="_blank" rel="noopener noreferrer">Acting for Film, TV & the Theatre</a> faculty member) was cast in the role of King Myand'r on <em><a href="https://www.imdb.com/title/tt1043813/?ref_=nm_flmg_act_6" target="_blank" rel="noopener noreferrer">Titans</a></em></li>\n \t<li>Nicole Redi (<a href="https://staging.torontofilmschool.ca/programs/film-production-diploma/" target="_blank" rel="noopener noreferrer">Film Production</a> '19) worked as a set dresser on the sets of<em> <a href="https://www.imdb.com/title/tt2177268/?ref_=fn_al_tt_1" target="_blank" rel="noopener noreferrer">Clarice</a></em>, <em><a href="https://www.imdb.com/title/tt1043813/?ref_=nm_flmg_act_6" target="_blank" rel="noopener noreferrer">Titans</a></em> and <em><a href="https://www.imdb.com/title/tt5171438/?ref_=nm_flmg_ardp_1" target="_blank" rel="noopener noreferrer">Star Trek: Discovery</a></em></li>\n \t<li>Heather Young (<a href="https://staging.torontofilmschool.ca/programs/film-production-diploma/" target="_blank" rel="noopener noreferrer">Film Production</a> '12) worked as a production coordinator on the set of<em> <a href="https://www.imdb.com/title/tt2177268/?ref_=fn_al_tt_1" target="_blank" rel="noopener noreferrer">Clarice</a></em></li>\n </ul>\n \n \n <img class="aligncenter wp-image-22831 size-medium" src="https://uat.tfs.staging.poundandgrain.ca/app/uploads/2023/03/TFS_ALL_PresidentBarnsley3_0510-1-670x393-1.jpg" alt="Andrew Barnsley with Golden Globe and Emmy awards" width="670" height="393" />\n \n \n <p style="font-weight: 400;">Toronto Film School’s Golden Globe- and <a href="https://staging.torontofilmschool.ca/blog/andrew-barnsley-celebrates-schitts-creeks-historic-night-at-emmys/" target="_blank" rel="noopener noreferrer">Emmy-winning</a> President, <a href="https://staging.torontofilmschool.ca/blog/toronto-film-school-poised-for-global-greatness-with-andrew-barnsley-at-the-helm-as-newly-named-president/" target="_blank" rel="noopener noreferrer">Andrew Barnsley</a>, said it came as no surprise to him that TFS alumni were found working on many of the biggest productions in the city last year.</p>\n \n <p style="font-weight: 400;">“My dream is to see Toronto Film School students on the sets of every major production not just here in Toronto, but all across Canada,” he said.</p>\n \n <p style="font-weight: 400;">“Our graduates are not only be ‘set-ready’ but ‘industry-ready’ – confident that they have mastered their craft and gained important insights into an industry that is fast-paced, exciting and demanding.”</p>\n \n <p style="font-weight: 400;">Indeed, Toronto Film School was named one of <a href="https://www.moviemaker.com/best-film-schools-in-the-us-and-canada-2021/5/" target="_blank" rel="noopener noreferrer">2021’s Best Film Schools in the U.S. and Canada</a> for the third consecutive year by <em>MovieMaker</em> magazine – the same Los Angeles-based industry publication that ranked Toronto number two on its list of the <a href="https://www.moviemaker.com/best-places-to-live-and-work-as-a-moviemaker-in-2022/" target="_blank" rel="noopener noreferrer">Best Places to Live and Work as a Moviemaker in 2022.</a></p>\n \n <p style="font-weight: 400;"> “This feels like the beginning of a good news story. It feels like we’re on track for future, continued growth,” Barnsley added.</p>\n \n <p style="font-weight: 400;">“And I think Toronto Film School students should be feeling very confident going into an industry that will value their education.”</p>\n \n \n """ |
post_title | "TFS Graduates Contribute to Year of “Historic” Growth for City’s Screen Production Industry"
|
post_excerpt | "" |
post_status | "publish"
|
comment_status | "closed"
|
ping_status | "open"
|
post_password | "" |
post_name | "tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry"
|
to_ping | "" |
pinged | "" |
post_modified | "2023-04-04 19:08:35"
|
post_modified_gmt | "2023-04-04 19:08:35"
|
post_content_filtered | "" |
post_parent | 0
|
guid | "https://uat.tfs.staging.poundandgrain.ca/?p=25194"
|
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/tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry/"
|
USER | "forge"
|
HOME | "/home/forge"
|
HTTP_REFERER | "https://uat.tfs.staging.poundandgrain.ca/blog/tfs-graduates-contribute-to-year-of-historic-growth-for-citys-screen-production-industry"
|
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 | "uat.tfs.staging.poundandgrain.ca"
|
REDIRECT_STATUS | "200"
|
HTTPS | "on"
|
SERVER_NAME | "uat.tfs.staging.poundandgrain.ca"
|
SERVER_PORT | "443"
|
SERVER_ADDR | "10.0.1.187"
|
REMOTE_PORT | "46434"
|
REMOTE_ADDR | "18.191.91.15"
|
GATEWAY_INTERFACE | "CGI/1.1"
|
SERVER_PROTOCOL | "HTTP/2.0"
|
DOCUMENT_ROOT | "/home/forge/uat.tfs.staging.poundandgrain.ca/releases/20241113033749/web"
|
DOCUMENT_URI | "/index.php"
|
SCRIPT_NAME | "/index.php"
|
SCRIPT_FILENAME | "/home/forge/uat.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 | 1736361867.4492
|
REQUEST_TIME | 1736361867
|
DB_NAME | "tfs_uat"
|
DB_USER | "***"
|
DB_PASSWORD | "************"
|
WP_ENV | "development"
|
WP_HOME | "https://uat.tfs.staging.poundandgrain.ca"
|
WP_SITEURL | "https://uat.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"
|
MIRROR_URL | "https://dev.tfs.staging.poundandgrain.ca"
|
SOURCE_OF_TRUTH | "false;"
|
BLOG_URL | "https://dev.tfs.staging.poundandgrain.ca"
|
Key | Value |
DB_NAME | "tfs_uat"
|
DB_USER | "***"
|
DB_PASSWORD | "************"
|
WP_ENV | "development"
|
WP_HOME | "https://uat.tfs.staging.poundandgrain.ca"
|
WP_SITEURL | "https://uat.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"
|
MIRROR_URL | "https://dev.tfs.staging.poundandgrain.ca"
|
SOURCE_OF_TRUTH | "false;"
|
BLOG_URL | "https://dev.tfs.staging.poundandgrain.ca"
|