All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] add clear screen command
@ 2009-04-08 19:04 Carlos Roberto do Nascimento Costa
  2009-04-08 19:21 ` Felix Zielcke
  0 siblings, 1 reply; 8+ messages in thread
From: Carlos Roberto do Nascimento Costa @ 2009-04-08 19:04 UTC (permalink / raw)
  To: grub-devel; +Cc: Manoel Rebelo Abranches

[-- Attachment #1: Type: text/plain, Size: 240 bytes --]

Hello,

This simple patch will add a new command to clear the terminal screen. Very
useful on the command-line.

Best Regards,

-- 
Carlos Roberto do Nascimento Costa
e-mail: crncosta@linux.vnet.ibm.com
IBM - Linux Technology Center Brasil

[-- Attachment #2: clear.patch --]
[-- Type: text/x-patch, Size: 2524 bytes --]

Index: conf/common.rmk
===================================================================
--- conf/common.rmk	(revision 2070)
+++ conf/common.rmk	(working copy)
@@ -332,7 +332,7 @@
 
 # Commands.
 pkglib_MODULES += minicmd.mod extcmd.mod hello.mod handler.mod	\
-	 ls.mod	cmp.mod cat.mod help.mod search.mod		\
+	 ls.mod	cmp.mod cat.mod help.mod search.mod clear.mod  \
 	loopback.mod fs_uuid.mod configfile.mod echo.mod	\
 	terminfo.mod test.mod blocklist.mod hexdump.mod		\
 	read.mod sleep.mod loadenv.mod crc.mod parttool.mod pcpart.mod
@@ -382,6 +382,11 @@
 cat_mod_CFLAGS = $(COMMON_CFLAGS)
 cat_mod_LDFLAGS = $(COMMON_LDFLAGS)
 
+# For clear.mod
+clear_mod_SOURCES = commands/clear.c
+clear_mod_CFLAGS = $(COMMON_CFLAGS)
+clear_mod_LDFLAGS = $(COMMON_LDFLAGS)
+
 # For echo.mod
 echo_mod_SOURCES = commands/echo.c
 echo_mod_CFLAGS = $(COMMON_CFLAGS)
Index: commands/clear.c
===================================================================
--- commands/clear.c	(revision 0)
+++ commands/clear.c	(revision 0)
@@ -0,0 +1,50 @@
+/* clear.c - command to clear the terminal screen. */
+/*
+ *  GRUB  --  GRand Unified Bootloader
+ *  Copyright (C) 2003,2007  Free Software Foundation, Inc.
+ *  Copyright (C) 2003  NIIBE Yutaka <gniibe@m17n.org>
+ *
+ *  GRUB is free software: you can redistribute it and/or modify
+ *  it under the terms of the GNU General Public License as published by
+ *  the Free Software Foundation, either version 3 of the License, or
+ *  (at your option) any later version.
+ *
+ *  GRUB is distributed in the hope that it will be useful,
+ *  but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *  GNU General Public License for more details.
+ *
+ *  You should have received a copy of the GNU General Public License
+ *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <grub/types.h>
+#include <grub/misc.h>
+#include <grub/err.h>
+#include <grub/dl.h>
+#include <grub/term.h>
+#include <grub/command.h>
+
+
+static grub_err_t
+grub_cmd_clear (struct grub_extcmd *cmd __attribute__ ((unused)),
+		int argc __attribute__ ((unused)),
+		char **args __attribute__ ((unused)))
+{
+  grub_cls ();
+  return 0;
+}
+
+static grub_command_t cmd;
+
+GRUB_MOD_INIT(clear)
+{
+  (void)mod;			/* To stop warning. */
+  cmd = grub_register_command ("clear", grub_cmd_clear,
+               0, "Clear the terminal screen.");
+}
+
+GRUB_MOD_FINI(clear)
+{
+  grub_unregister_extcmd (cmd);
+}

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] add clear screen command
  2009-04-08 19:04 [PATCH] add clear screen command Carlos Roberto do Nascimento Costa
@ 2009-04-08 19:21 ` Felix Zielcke
  2009-04-08 19:32   ` phcoder
  2009-04-08 22:34   ` Carlos Roberto do Nascimento Costa
  0 siblings, 2 replies; 8+ messages in thread
From: Felix Zielcke @ 2009-04-08 19:21 UTC (permalink / raw)
  To: The development of GRUB 2

Am Mittwoch, den 08.04.2009, 16:04 -0300 schrieb Carlos Roberto do
Nascimento Costa:
> Hello,
> 
> This simple patch will add a new command to clear the terminal screen. Very
> useful on the command-line.
> 

Hello,

+ *  Copyright (C) 2003,2007  Free Software Foundation, Inc.
+ *  Copyright (C) 2003  NIIBE Yutaka <gniibe@m17n.org>

This should be just `Copyright (C) 2009  Free Software Foundation, Inc.',
because it's a new file from this year.

+  (void)mod;                   /* To stop warning. */
+  cmd = grub_register_command ("clear", grub_cmd_clear,
+               0, "Clear the terminal screen.");

I think there shouldn't be a `0' but `GRUB_COMMAND_FLAG_CMDLINE'.
And please write a ChangeLog entry.

-- 
Felix Zielcke




^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] add clear screen command
  2009-04-08 19:21 ` Felix Zielcke
@ 2009-04-08 19:32   ` phcoder
  2009-04-08 22:51     ` Carlos Roberto do Nascimento Costa
  2009-04-08 22:34   ` Carlos Roberto do Nascimento Costa
  1 sibling, 1 reply; 8+ messages in thread
From: phcoder @ 2009-04-08 19:32 UTC (permalink / raw)
  To: The development of GRUB 2

Perhaps putting it into normal.mod instead of separate module is a good idea
Felix Zielcke wrote:
> Am Mittwoch, den 08.04.2009, 16:04 -0300 schrieb Carlos Roberto do
> Nascimento Costa:
>> Hello,
>>
>> This simple patch will add a new command to clear the terminal screen. Very
>> useful on the command-line.
>>
> 
> Hello,
> 
> + *  Copyright (C) 2003,2007  Free Software Foundation, Inc.
> + *  Copyright (C) 2003  NIIBE Yutaka <gniibe@m17n.org>
> 
> This should be just `Copyright (C) 2009  Free Software Foundation, Inc.',
> because it's a new file from this year.
> 
> +  (void)mod;                   /* To stop warning. */
> +  cmd = grub_register_command ("clear", grub_cmd_clear,
> +               0, "Clear the terminal screen.");
> 
> I think there shouldn't be a `0' but `GRUB_COMMAND_FLAG_CMDLINE'.
> And please write a ChangeLog entry.
> 


-- 

Regards
Vladimir 'phcoder' Serbinenko



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] add clear screen command
  2009-04-08 19:21 ` Felix Zielcke
  2009-04-08 19:32   ` phcoder
@ 2009-04-08 22:34   ` Carlos Roberto do Nascimento Costa
  2009-04-08 22:45     ` phcoder
  1 sibling, 1 reply; 8+ messages in thread
From: Carlos Roberto do Nascimento Costa @ 2009-04-08 22:34 UTC (permalink / raw)
  To: The development of GRUB 2

[-- Attachment #1: Type: text/plain, Size: 1062 bytes --]

Hi Felix, thank you for reviewing this patch.

Felix Zielcke wrote:
> Hello,
> 
> + *  Copyright (C) 2003,2007  Free Software Foundation, Inc.
> + *  Copyright (C) 2003  NIIBE Yutaka <gniibe@m17n.org>
> 
> This should be just `Copyright (C) 2009  Free Software Foundation, Inc.',
> because it's a new file from this year.

My bad, I'm sorry. Now is fixed, see new [clear2.patch] file attached.

> +  (void)mod;                   /* To stop warning. */
> +  cmd = grub_register_command ("clear", grub_cmd_clear,
> +               0, "Clear the terminal screen.");
> 
> I think there shouldn't be a `0' but `GRUB_COMMAND_FLAG_CMDLINE'.

Yes, you are right. grub_register_command isn't the correct function to register
a command and grub_register_extcmd is the new way. However, there are still
modules need to be fixed, right?! I'll write another e-mail about it soon.

> And please write a ChangeLog entry.
> 

My bad. Now fixed too.

Best Regards,

-- 
Carlos Roberto do Nascimento Costa
E-mails: crncosta@linux.vnet.ibm.com
IBM - Linux Technology Center Brasil

[-- Attachment #2: clear2.patch --]
[-- Type: text/x-patch, Size: 3031 bytes --]

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 2073)
+++ ChangeLog	(working copy)
@@ -1,3 +1,11 @@
+2009-04-08  Carlos Costa  <crncosta@linux.vnet.ibm.com>
+
+	* commands/clear.c: new file.
+	* conf/common.rmk (pkglib_MODULES):	Added clear.mod.
+	(clear_mod_SOURCES): new variable.
+	(clear_mod_CFLAGS): likewise.
+	(clear_mod_LDFLAGS): likewise.
+
 2009-04-08  Felix Zielcke  <fzielcke@z-51.de>
 
 	* disk/lvm.c (grub_lvm_scan_device): Add a missing NULL check.
Index: commands/clear.c
===================================================================
--- commands/clear.c	(revision 0)
+++ commands/clear.c	(revision 0)
@@ -0,0 +1,50 @@
+/* clear.c - command to clear the terminal screen. */
+/*
+ *  GRUB  --  GRand Unified Bootloader
+ *  Copyright (C) 2009  Free Software Foundation, Inc.
+ *
+ *  GRUB is free software: you can redistribute it and/or modify
+ *  it under the terms of the GNU General Public License as published by
+ *  the Free Software Foundation, either version 3 of the License, or
+ *  (at your option) any later version.
+ *
+ *  GRUB is distributed in the hope that it will be useful,
+ *  but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *  GNU General Public License for more details.
+ *
+ *  You should have received a copy of the GNU General Public License
+ *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <grub/types.h>
+#include <grub/misc.h>
+#include <grub/err.h>
+#include <grub/dl.h>
+#include <grub/term.h>
+#include <grub/command.h>
+
+
+static grub_err_t
+grub_cmd_clear (struct grub_extcmd *cmd __attribute__ ((unused)),
+		int argc __attribute__ ((unused)),
+		char **args __attribute__ ((unused)))
+{
+  grub_cls ();
+  return 0;
+}
+
+static grub_command_t cmd;
+
+GRUB_MOD_INIT(clear)
+{
+  (void)mod;			/* To stop warning. */
+  cmd = grub_register_extcmd ("clear", grub_cmd_clear,
+            GRUB_COMMAND_FLAG_CMDLINE,"clear",
+            "Clear the terminal screen.",0);
+}
+
+GRUB_MOD_FINI(clear)
+{
+  grub_unregister_extcmd (cmd);
+}
Index: conf/common.rmk
===================================================================
--- conf/common.rmk	(revision 2073)
+++ conf/common.rmk	(working copy)
@@ -332,7 +332,7 @@
 
 # Commands.
 pkglib_MODULES += minicmd.mod extcmd.mod hello.mod handler.mod	\
-	 ls.mod	cmp.mod cat.mod help.mod search.mod		\
+	 ls.mod	cmp.mod cat.mod help.mod search.mod clear.mod  \
 	loopback.mod fs_uuid.mod configfile.mod echo.mod	\
 	terminfo.mod test.mod blocklist.mod hexdump.mod		\
 	read.mod sleep.mod loadenv.mod crc.mod parttool.mod pcpart.mod
@@ -382,6 +382,11 @@
 cat_mod_CFLAGS = $(COMMON_CFLAGS)
 cat_mod_LDFLAGS = $(COMMON_LDFLAGS)
 
+# For clear.mod
+clear_mod_SOURCES = commands/clear.c
+clear_mod_CFLAGS = $(COMMON_CFLAGS)
+clear_mod_LDFLAGS = $(COMMON_LDFLAGS)
+
 # For echo.mod
 echo_mod_SOURCES = commands/echo.c
 echo_mod_CFLAGS = $(COMMON_CFLAGS)

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] add clear screen command
  2009-04-08 22:34   ` Carlos Roberto do Nascimento Costa
@ 2009-04-08 22:45     ` phcoder
  0 siblings, 0 replies; 8+ messages in thread
From: phcoder @ 2009-04-08 22:45 UTC (permalink / raw)
  To: The development of GRUB 2

Carlos Roberto do Nascimento Costa wrote:

>> +  (void)mod;                   /* To stop warning. */
>> +  cmd = grub_register_command ("clear", grub_cmd_clear,
>> +               0, "Clear the terminal screen.");
>>
>> I think there shouldn't be a `0' but `GRUB_COMMAND_FLAG_CMDLINE'.
> 
> Yes, you are right. grub_register_command isn't the correct function to register
> a command and grub_register_extcmd is the new way. However, there are still
> modules need to be fixed, right?! I'll write another e-mail about it soon.
> 
Your declaration is correct

> 
> ------------------------------------------------------------------------
> 
> _______________________________________________
> Grub-devel mailing list
> Grub-devel@gnu.org
> http://lists.gnu.org/mailman/listinfo/grub-devel


-- 

Regards
Vladimir 'phcoder' Serbinenko



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] add clear screen command
  2009-04-08 19:32   ` phcoder
@ 2009-04-08 22:51     ` Carlos Roberto do Nascimento Costa
  2009-04-09 13:44       ` phcoder
  0 siblings, 1 reply; 8+ messages in thread
From: Carlos Roberto do Nascimento Costa @ 2009-04-08 22:51 UTC (permalink / raw)
  To: The development of GRUB 2

Hello phcoder. thank you for reviewing this patch.

phcoder wrote:
> Perhaps putting it into normal.mod instead of separate module is a good
> idea

When I did this patch, I was thinking: clear is a command like ls, lspci,
reboot, sleep, suspend, halt, exit, etc... so, clear needs to be at commands/
dir and follows the same ideas behind other commands.

Is there any reason to not follows this idea?

Best regards,

-- 
Carlos Roberto do Nascimento Costa
E-mails: crncosta@linux.vnet.ibm.com
IBM - Linux Technology Center Brasil



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] add clear screen command
  2009-04-08 22:51     ` Carlos Roberto do Nascimento Costa
@ 2009-04-09 13:44       ` phcoder
  2009-04-09 22:16         ` Manoel Rebelo Abranches
  0 siblings, 1 reply; 8+ messages in thread
From: phcoder @ 2009-04-09 13:44 UTC (permalink / raw)
  To: The development of GRUB 2

Carlos Roberto do Nascimento Costa wrote:
> Hello phcoder. thank you for reviewing this patch.
You're welcome
> 
> phcoder wrote:
>> Perhaps putting it into normal.mod instead of separate module is a good
>> idea
> 
> When I did this patch, I was thinking: clear is a command like ls, lspci,
> reboot, sleep, suspend, halt, exit, etc... so, clear needs to be at commands/
> dir and follows the same ideas behind other commands.
> 
> Is there any reason to not follows this idea?
> 
With your patch the created elf contains much more overhead then code. 
While it isn't really a problem it's still a thing about which some 
thinking is needed
> Best regards,
> 


-- 

Regards
Vladimir 'phcoder' Serbinenko



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] add clear screen command
  2009-04-09 13:44       ` phcoder
@ 2009-04-09 22:16         ` Manoel Rebelo Abranches
  0 siblings, 0 replies; 8+ messages in thread
From: Manoel Rebelo Abranches @ 2009-04-09 22:16 UTC (permalink / raw)
  To: The development of GRUB 2

On Thu, 2009-04-09 at 15:44 +0200, phcoder wrote:
> Carlos Roberto do Nascimento Costa wrote:
> > Hello phcoder. thank you for reviewing this patch.
> You're welcome
> > 
> > phcoder wrote:
> >> Perhaps putting it into normal.mod instead of separate module is a good
> >> idea
> > 
> > When I did this patch, I was thinking: clear is a command like ls, lspci,
> > reboot, sleep, suspend, halt, exit, etc... so, clear needs to be at commands/
> > dir and follows the same ideas behind other commands.
> > 
> > Is there any reason to not follows this idea?
> > 
> With your patch the created elf contains much more overhead then code. 
> While it isn't really a problem it's still a thing about which some 
> thinking is needed
> > Best regards,
> > 
> 
> 
I think this overhead is not very relevant since this module won't go in
the image (created by grub-mkimage). Also it will be consistent with the
other commands and better organized(the halt command is actually very
similar).

-- 
Best Regards,

Manoel Rebelo Abranches 
IBM Linux Technology Center Brazil




^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2009-04-09 22:16 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-04-08 19:04 [PATCH] add clear screen command Carlos Roberto do Nascimento Costa
2009-04-08 19:21 ` Felix Zielcke
2009-04-08 19:32   ` phcoder
2009-04-08 22:51     ` Carlos Roberto do Nascimento Costa
2009-04-09 13:44       ` phcoder
2009-04-09 22:16         ` Manoel Rebelo Abranches
2009-04-08 22:34   ` Carlos Roberto do Nascimento Costa
2009-04-08 22:45     ` phcoder

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.