Laravel - Carbon Macro Call to undefined Method
up vote
1
down vote
favorite
I created a CarbonServiceProvider
class using php artisan make:provider CarbonServiceProvider
and added it in the providers
array in my app.php
file.
In the boot()
method I added this macro:
public function boot()
{
if(!Carbon::hasMacro('nextWorkingDaySameTime')){
Carbon::macro('nextWorkingDaySameTime', function ($startHour = 8, $endHour = 17) {
[...]
return $this;
});
}
}
I paid attention to use IlluminateSupportCarbon;
instead of CarbonCarbon
, since then it says that macro()
would be undefined.
Whenever I call this macro like so:
CarbonCarbon::nextWorkingDaySameTime();
it fails with the following message:
Call to undefined method CarbonCarbon::nextWorkingDaySameTime()
php laravel macros php-carbon
|
show 1 more comment
up vote
1
down vote
favorite
I created a CarbonServiceProvider
class using php artisan make:provider CarbonServiceProvider
and added it in the providers
array in my app.php
file.
In the boot()
method I added this macro:
public function boot()
{
if(!Carbon::hasMacro('nextWorkingDaySameTime')){
Carbon::macro('nextWorkingDaySameTime', function ($startHour = 8, $endHour = 17) {
[...]
return $this;
});
}
}
I paid attention to use IlluminateSupportCarbon;
instead of CarbonCarbon
, since then it says that macro()
would be undefined.
Whenever I call this macro like so:
CarbonCarbon::nextWorkingDaySameTime();
it fails with the following message:
Call to undefined method CarbonCarbon::nextWorkingDaySameTime()
php laravel macros php-carbon
I paid attention to use IlluminateSupportCarbon; instead of CarbonCarbon - don't you also need to do the same when calling your macro? It looks like you're trying to run it on theCarbon
class itself
– iainn
Nov 22 at 13:56
You may need to docomposer dump-autoload
I guess. And I thinkCarbonCarbon
should do the job instead
– Oluwatobi Samuel Omisakin
Nov 22 at 13:58
@iainn Hm, good catch. I've tried it with the other class but it ends up in telling meUsing $this when not in object context
even when I instantlyreturn $this
without modifying anything.
– Scarwolf
Nov 22 at 13:59
@OluwatobiSamuelOmisakin This ends up inCall to undefined method CarbonCarbon::hasMacro()
even after dumping composer autoload...
– Scarwolf
Nov 22 at 14:01
What do you expect$this
to be? Because as the error mentions you are at that point not in a class scope, so you can not use$this
there
– Sven Hakvoort
Nov 22 at 14:40
|
show 1 more comment
up vote
1
down vote
favorite
up vote
1
down vote
favorite
I created a CarbonServiceProvider
class using php artisan make:provider CarbonServiceProvider
and added it in the providers
array in my app.php
file.
In the boot()
method I added this macro:
public function boot()
{
if(!Carbon::hasMacro('nextWorkingDaySameTime')){
Carbon::macro('nextWorkingDaySameTime', function ($startHour = 8, $endHour = 17) {
[...]
return $this;
});
}
}
I paid attention to use IlluminateSupportCarbon;
instead of CarbonCarbon
, since then it says that macro()
would be undefined.
Whenever I call this macro like so:
CarbonCarbon::nextWorkingDaySameTime();
it fails with the following message:
Call to undefined method CarbonCarbon::nextWorkingDaySameTime()
php laravel macros php-carbon
I created a CarbonServiceProvider
class using php artisan make:provider CarbonServiceProvider
and added it in the providers
array in my app.php
file.
In the boot()
method I added this macro:
public function boot()
{
if(!Carbon::hasMacro('nextWorkingDaySameTime')){
Carbon::macro('nextWorkingDaySameTime', function ($startHour = 8, $endHour = 17) {
[...]
return $this;
});
}
}
I paid attention to use IlluminateSupportCarbon;
instead of CarbonCarbon
, since then it says that macro()
would be undefined.
Whenever I call this macro like so:
CarbonCarbon::nextWorkingDaySameTime();
it fails with the following message:
Call to undefined method CarbonCarbon::nextWorkingDaySameTime()
php laravel macros php-carbon
php laravel macros php-carbon
asked Nov 22 at 13:53
Scarwolf
3761421
3761421
I paid attention to use IlluminateSupportCarbon; instead of CarbonCarbon - don't you also need to do the same when calling your macro? It looks like you're trying to run it on theCarbon
class itself
– iainn
Nov 22 at 13:56
You may need to docomposer dump-autoload
I guess. And I thinkCarbonCarbon
should do the job instead
– Oluwatobi Samuel Omisakin
Nov 22 at 13:58
@iainn Hm, good catch. I've tried it with the other class but it ends up in telling meUsing $this when not in object context
even when I instantlyreturn $this
without modifying anything.
– Scarwolf
Nov 22 at 13:59
@OluwatobiSamuelOmisakin This ends up inCall to undefined method CarbonCarbon::hasMacro()
even after dumping composer autoload...
– Scarwolf
Nov 22 at 14:01
What do you expect$this
to be? Because as the error mentions you are at that point not in a class scope, so you can not use$this
there
– Sven Hakvoort
Nov 22 at 14:40
|
show 1 more comment
I paid attention to use IlluminateSupportCarbon; instead of CarbonCarbon - don't you also need to do the same when calling your macro? It looks like you're trying to run it on theCarbon
class itself
– iainn
Nov 22 at 13:56
You may need to docomposer dump-autoload
I guess. And I thinkCarbonCarbon
should do the job instead
– Oluwatobi Samuel Omisakin
Nov 22 at 13:58
@iainn Hm, good catch. I've tried it with the other class but it ends up in telling meUsing $this when not in object context
even when I instantlyreturn $this
without modifying anything.
– Scarwolf
Nov 22 at 13:59
@OluwatobiSamuelOmisakin This ends up inCall to undefined method CarbonCarbon::hasMacro()
even after dumping composer autoload...
– Scarwolf
Nov 22 at 14:01
What do you expect$this
to be? Because as the error mentions you are at that point not in a class scope, so you can not use$this
there
– Sven Hakvoort
Nov 22 at 14:40
I paid attention to use IlluminateSupportCarbon; instead of CarbonCarbon - don't you also need to do the same when calling your macro? It looks like you're trying to run it on the
Carbon
class itself– iainn
Nov 22 at 13:56
I paid attention to use IlluminateSupportCarbon; instead of CarbonCarbon - don't you also need to do the same when calling your macro? It looks like you're trying to run it on the
Carbon
class itself– iainn
Nov 22 at 13:56
You may need to do
composer dump-autoload
I guess. And I think CarbonCarbon
should do the job instead– Oluwatobi Samuel Omisakin
Nov 22 at 13:58
You may need to do
composer dump-autoload
I guess. And I think CarbonCarbon
should do the job instead– Oluwatobi Samuel Omisakin
Nov 22 at 13:58
@iainn Hm, good catch. I've tried it with the other class but it ends up in telling me
Using $this when not in object context
even when I instantly return $this
without modifying anything.– Scarwolf
Nov 22 at 13:59
@iainn Hm, good catch. I've tried it with the other class but it ends up in telling me
Using $this when not in object context
even when I instantly return $this
without modifying anything.– Scarwolf
Nov 22 at 13:59
@OluwatobiSamuelOmisakin This ends up in
Call to undefined method CarbonCarbon::hasMacro()
even after dumping composer autoload...– Scarwolf
Nov 22 at 14:01
@OluwatobiSamuelOmisakin This ends up in
Call to undefined method CarbonCarbon::hasMacro()
even after dumping composer autoload...– Scarwolf
Nov 22 at 14:01
What do you expect
$this
to be? Because as the error mentions you are at that point not in a class scope, so you can not use $this
there– Sven Hakvoort
Nov 22 at 14:40
What do you expect
$this
to be? Because as the error mentions you are at that point not in a class scope, so you can not use $this
there– Sven Hakvoort
Nov 22 at 14:40
|
show 1 more comment
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53432505%2flaravel-carbon-macro-call-to-undefined-method%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53432505%2flaravel-carbon-macro-call-to-undefined-method%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
I paid attention to use IlluminateSupportCarbon; instead of CarbonCarbon - don't you also need to do the same when calling your macro? It looks like you're trying to run it on the
Carbon
class itself– iainn
Nov 22 at 13:56
You may need to do
composer dump-autoload
I guess. And I thinkCarbonCarbon
should do the job instead– Oluwatobi Samuel Omisakin
Nov 22 at 13:58
@iainn Hm, good catch. I've tried it with the other class but it ends up in telling me
Using $this when not in object context
even when I instantlyreturn $this
without modifying anything.– Scarwolf
Nov 22 at 13:59
@OluwatobiSamuelOmisakin This ends up in
Call to undefined method CarbonCarbon::hasMacro()
even after dumping composer autoload...– Scarwolf
Nov 22 at 14:01
What do you expect
$this
to be? Because as the error mentions you are at that point not in a class scope, so you can not use$this
there– Sven Hakvoort
Nov 22 at 14:40