Hello world/Newline omission

Pete: /* {{header|Limbo}} */ Apparently it's "Good-bye" here. Sorry!


{{task|Basic language learning}}

Some languages automatically insert a newline after outputting a string, unless measures are taken to prevent its output. The purpose of this task is to output the string "Goodbye, World!" without a trailing newline.

'''See also'''
* [[Hello world/Graphical]]
* [[Hello world/Line Printer]]
* [[Hello world/Standard error]]
* [[Hello world/Text]]

=={{header|ACL2}}==
(cw "Goodbye, World!")

=={{header|Ada}}==

with Ada.Text_IO;

procedure Goodbye_World is
begin
Ada.Text_IO.Put("Goodbye, World!");
end Goodbye_World;


=={{header|ATS}}==
implement main () = print "Goodbye, World!"

=={{header|AutoHotkey}}==
DllCall("AllocConsole")
FileAppend, Goodbye`, World!, CONOUT$ ; No newline outputted
MsgBox

=={{header|AWK}}==

BEGIN { printf("Goodbye, World!") }

=={{header|BASIC}}==
10 REM The trailing semicolon prevents a newline
20 PRINT "Goodbye, World!";


=={{header|BASIC256}}==
Output all on a single line.
print "Goodbye,";
print " ";
print "World!";


=={{header|Batch File}}==
'''Under normal circumstances, when delayed expansion is disabled'''

The quoted form guarantees there are no hidden trailing spaces after World!


'''If delayed expansion is enabled, then the ! must be escaped'''

Escape once if quoted form, twice if unquoted.
setlocal enableDelayedExpansion


=={{header|BBC BASIC}}==
REM BBC BASIC accepts the standard trailing semicolon:
PRINT "Goodbye World!";

REM One could also output the characters individually:
GW$ = "Goodbye World!"
FOR i% = 1 TO LEN(GW$)
VDU ASCMID$(GW$, i%)
NEXT


=={{header|Bracmat}}==

put$"Goodbye, World!"

=={{header|C}}==
In C, we do not get a newline unless we embed one:
#include

int main(int argc, char *argv[]) {
(void) printf("Goodbye, World!"); /* No automatic newline */
return EXIT_SUCCESS;
}


However ISO C leaves it up to implementations to define whether or not the last line of a text stream requires a new-line. This means that the C can be targetted to environments where this task is impossible to implement, at least with a direct text stream manipulation like this.

=={{header|C++}}==
In C++, using iostreams, portable newlines come from std::endl. Non-portable newlines may come from using constructs like \n, \r or \r\n. If we don't use any of these, we won't get a newline.
#include

int main(int argc, char *argv[]) {
std::cout << "Goodbye, World!";
}


=={{header|C sharp|C#}}==
using System;

class Program {
static void Main (string[] args) {
//Using Console.WriteLine() will append a newline
Console.WriteLine("Goodbye, World!");

//Using Console.Write() will not append a newline
Console.Write("Goodbye, World!");
}
}


=={{header|Clipper}}==
?? "Goodbye, World!"

=={{header|Clojure}}==
(print "Goodbye, World!")

=={{header|COBOL}}==
IDENTIFICATION DIVISION.
PROGRAM-ID. GOODBYE-WORLD.

PROCEDURE DIVISION.
DISPLAY 'Goodbye, World!'
WITH NO ADVANCING
END-DISPLAY
.
STOP RUN.


=={{header|Common Lisp}}==
(princ "Goodbye, World!")
=={{header|Creative Basic}}==

'In a window

DEF Win:WINDOW
DEF Close:CHAR
DEF ScreenSizeX,ScreenSizeY:INT

GETSCREENSIZE(ScreenSizeX,ScreenSizeY)

WINDOW Win,0,0,ScreenSizeX,ScreenSizeY,0,0,"Goodbye program",MainHandler

PRINT Win,"Goodbye, World!"
'Prints in the upper left corner of the window (position 0,0).
PRINT"Win," I ride off into the sunset."

'There does not appear to be a means of starting a new line when printing in a window, other than by using the MOVE command.
'Therefore, both sentences here will print on the same line, i.e., in the same vertical position.

WAITUNTIL Close=1

CLOSEWINDOW Win

END

SUB MainHandler

IF @CLASS=@IDCLOSEWINDOW THEN Close=1

RETURN

'In the console

OPENCONSOLE

'Insert a trailing comma.
PRINT"Goodbye, World!",
PRINT" I ride off into the sunset."

PRINT:PRINT"Press any key to end."

DO:UNTIL INKEY$<>""

CLOSECONSOLE

'Since this a Cbasic console program.
END


=={{header|D}}==
{{works with|D|2.0}}
import std.stdio;

void main() {
write("Goodbye, World!");
}

=={{header|Déjà Vu}}==
print\ "Goodbye, World!"

=={{header|Delphi}}==
program Project1;

{$APPTYPE CONSOLE}

begin
Write('Goodbye, World!');
end.


=={{header|Dylan.NET}}==
{{works with|Mono|2.6.7}}
{{works with|Mono|2.10.x}}
{{works with|.NET|3.5}}
{{works with|.NET|4.0}}
One Line version:
Console::Write("Goodbye, World!")
Goodbye World Program:

//compile using the new dylan.NET v, 11.3.1.3 or later
//use mono to run the compiler
#refstdasm mscorlib.dll

import System

assembly gdbyeex exe
ver 1.1.0.0

class public auto ansi Module1

method public static void main()
Console::Write("Goodbye, World!")
end method

end class


=={{header|DWScript}}==
Print('Goodbye, World!');

=={{header|Erlang}}==
In erlang a newline must be specified in the format string.
io:format("Goodbye, world!").

=={{header|Euphoria}}==
-- In Euphoria puts() does not insert a newline character after outputting a string
puts(1,"Goodbye, world!")


=={{header|Factor}}==
USE: io
"Goodbye, World!" write


=={{header|Fantom}}==


class Main {
Void main() {
echo("Goodbye, World!")
}
}


=={{header|Frink}}==
print["Goodbye, World!"]

=={{header|Forth}}==
\ The Forth word ." does not insert a newline character after outputting a string
." Goodbye, World!"


=={{header|Fortran}}==
program bye
write (*,'(a)',advance='no') 'Goodbye, World!'
end program bye


=={{header|F Sharp|F#}}==

// A program that will run in the interpreter (fsi.exe)
printf "Goodbye, World!";;

// A compiled program
[]
let main args =
printf "Goodbye, World!"
0


=={{header|gecho}}==
{{incorrect|gecho|output isn't consistent with the task's requirements: wording, capitalization of the 2nd word.}}
'Hello, <> 'world! print

=={{header|GML}}==
show_message("Goodbye, World!")

=={{header|Go}}==
package main

import "fmt"

func main() { fmt.Print("Goodbye, World!") }


=={{header|GUISS}}==
In Graphical User Interface Support Script, we specify a newline, if we want one. The following will not produce a newline:
Start,Programs,Accessories,Notepad,Type:Goodbye World[pling]

=={{header|Groovy}}==

print "Goodbye, world"

=={{header|Harbour}}==
?? "Goodbye, world"

=={{header|Haskell}}==

main = putStr "Goodbye, world"

=={{header|Icon}} and {{header|Unicon}}==
Native output in Icon and Unicon is performed via the ''write'' and ''writes'' procedures. The ''write'' procedure terminates each line with both a return and newline (for consistency across platforms). The ''writes'' procedure omits this. Additionally, the programming library has a series of ''printf'' procedures as well.
procedure main()
writes("Goodbye, World!")
end


== {{header|Io}}==

write("Goodbye, World!")

=={{header|IWBASIC}}==

'In a window

DEF Win:WINDOW
DEF Close:CHAR
DEF ScreenSizeX,ScreenSizeY:UINT

GETSCREENSIZE(ScreenSizeX,ScreenSizeY)

OPENWINDOW Win,0,0,ScreenSizeX,ScreenSizeY,NULL,NULL,"Goodbye program",&MainHandler

PRINT Win,"Goodbye, World!"
'Prints in upper left corner of the window (position 0,0).
PRINT Win," You won't have this program to kick around anymore."

'There does not appear to be a means of starting a new line when printing in a window, other than by using the MOVE command.
'Therefore, both sentences here will print on the same line, i.e., in the same vertical position.

WAITUNTIL Close=1

CLOSEWINDOW Win

END

SUB MainHandler

IF @MESSAGE=@IDCLOSEWINDOW THEN Close=1

RETURN
ENDSUB

'In the console

OPENCONSOLE

'by inserting a trailing comma.
PRINT"Goodbye, World!",
PRINT" You won't have this program to kick around anymore."

PRINT:PRINT

'A press any key to continue message is automatic in a program compiled as console only.
'I presume the compiler adds the code.
CLOSECONSOLE

'Since this an IWBASIC console program.
END


=={{header|J}}==

'''Solution''':prompt from the misc package.
'''Example''': load'misc'
prompt 'hello world'
hello world

'''Notes''': J programs are normally run from a REPL, or session manager, which comes in several flavors. The traditional commandline-based terminal (jconsole), one of several desktop applications (jqt for the current version of J, jgtk and jwd for older but still supported versions), a web-based frontend (jhs), and various mobile apps (J for iOS, Android).

The specific session manager being used changes the context and therefore answer to this task. For example, when using J from a browser (including mobile browsers) newlines are omitted by default. Further, J provides strong tools for coalescing results and manipulating them prior to output, so newline elimination would typically happen before output rather than after.

With that said, prompt handles the most common cases (using binary output for jconsole, so no newline is appended; adjusting the REPL prompt in the desktop apps to to elide the newline which is normally included by default, etc).

For truly automated processes, you'd almost always want this kind of functionality (omitting the newline when printing) in a file- or stream-oriented application. For those cases, the simple text 1!:3 file will append the text to the referenced file verbatim, without inserting any extra newlines.

So, if a J programmer were asked to solve this task, the right approach would be to ask why that is needed, and then craft a solution appropriate to that situation.

=={{header|Java}}==
public class HelloWorld
{
public static void main(String[] args)
{
System.out.print("Goodbye, World!");
}
}


=={{header|Julia}}==
Julia provides a println function which appends a newline, and a print function which doesn't:
print("Goodbye, World!")

=={{header|Lasso}}==
Lasso provides a stdoutnl method that prints a trailing newline, and a stdout method that does not:
stdout("Goodbye, World!")

=={{header|LFE}}==

(: io format '"Hello, planetary orb!")


=={{header|Liberty BASIC}}==
A trailing semicolon prevents a newline
print "Goodbye, World!";


=={{header|Limbo}}==

implement HelloWorld;

include "sys.m"; sys: Sys;
include "draw.m";

HelloWorld: module {
init: fn(nil: ref Draw->Context, nil: list of string);
};

init(nil: ref Draw->Context, nil: list of string)
{
sys = load Sys Sys->PATH;
sys->print("Goodbye, World!"); # No automatic newline.
}


=={{header|Logtalk}}==
No action is necessary to avoid an unwanted newline.

:- object(error_message).

% the initialization/1 directive argument is automatically executed
% when the object is compiled loaded into memory:
:- initialization(write('Goodbye, World!')).

:- end_object.


=={{header|Lua}}==
io.write("Goodbye, World!")

=={{header|m4}}==

(Quoted) text is issued verbatim, "dnl" suppresses all input until and including the next newline. Simply creating an input without a trailing newline would of course accomplish the same task.

`Goodbye, World!'dnl

=={{header|Maple}}==

printf( "Goodbye, World!" );


=={{header|Mathematica}}==

NotebookWrite[EvaluationNotebook[], "Goodbye, World!"]


=={{header|MATLAB}} / {{header|Octave}}==
fprintf('Goodbye, World!');

=={{header|mIRC Scripting Language}}==
echo -ag Goodbye, World!

=={{header|ML/I}}==
===Simple solution===
In ML/I, if there isn't a newline in the input, there won't be one in the output; so a simple solution is this (although it's hard to see that there isn't a newline).
Goodbye, World!
===More sophisticated solution===
To make it clearer, we can define an ML/I ''skip'' to delete itself and an immediately following newline.
MCSKIP " WITH " NL
Goodbye, World!""


=={{header|Nemerle}}==

using System.Console;

module Hello
{
// as with C#, Write() does not append a newline
Write("Goodbye, world!");

// equivalently
Write("Goodbye, ");
Write("world!");
}


=={{header|NetRexx}}==
/* NetRexx */
options replace format comments java crossref symbols binary

say 'Goodbye, World!\-'


=={{header|NewLISP}}==
(print "Goodbye, World!")

=={{header|Objeck}}==


bundle Default {
class SayGoodbye {
function : Main(args : String[]) ~ Nil {
"Goodbye, World!"->Print();
}
}
}


=={{header|OCaml}}==

In OCaml, the function [http://caml.inria.fr/pub/docs/manual-ocaml/libref/Pervasives.html#VALprint_endline print_endline] prints a string followed by a newline character on the standard output and flush the standard output. And the function [http://caml.inria.fr/pub/docs/manual-ocaml/libref/Pervasives.html#VALprint_string print_string] just prints a string with nothing additional.

print_string "Goodbye, World!"

=={{header|Oxygene}}==
{{incorrect|Oxygene|output isn't consistent with the task's requirements: wording, capitalization.}}


namespace HelloWorld;

interface

type
HelloWorld = class
public
class method Main;
end;

implementation

class method HelloWorld.Main;
begin
Console.Write('Farewell, ');
Console.Write('cruel ');
Console.WriteLine('world!');
end;

end.


>HelloWorld.exe
Farewell, cruel world!


=={{header|Panoramic}}==

rem insert a trailing semicolon.
print "Goodbye, World!";
print " Nice having known you."


=={{header|PARI/GP}}==
print1("Goodbye, World!")

=={{header|PASM}}==

print "Goodbye World!" # Newlines do not occur unless we embed them
end


=={{header|Pascal}}==
program NewLineOmission(output);

begin
write('Goodbye, World!');
end.

Output:
% ./NewLineOmission 
Goodbye, World!%


=={{header|Perl}}==
print "Goodbye, World!"; # A newline does not occur automatically

=={{header|Perl 6}}==
A newline is not added automatically to print or printf
print "Goodbye, World!";
printf "%s", "Goodbye, World!";


=={{header|PHL}}==
Printf doesn't add newline automatically.

module helloworld_noln;
extern printf;

@Integer main [
printf("Goodbye, World!");
return 0;
]


=={{header|PicoLisp}}==
(prin "Goodbye, world")

=={{header|PL/I}}==

put ('Goodbye, World!');


=={{header|PureBasic}}==
OpenConsole()
Print("Goodbye, World!")
Input() ;wait for enter key to be pressed


=={{header|Python}}==
import sys
sys.stdout.write("Goodbye, World!")


{{works with|Python|3.x}}
print("Goodbye, World!", end="")

=={{header|Racket}}==
#lang racket
(display "Goodbye, World!")


=={{header|Retro}}==
"Goodbye, World!" puts

=={{header|REXX}}==
It should be noted that upon a REXX program completion, any text left pending without a C/R (or newline) is followed by a

blank line so as to not leave the state of the terminal with malformed "text lines" (which can be followed by other text

(lines) from a calling program(s), or the operating system (shell) which is usually some sort of a "prompt" text string.
/*REXX pgm displays a "Goodbye, World!" without a trailing newline. */

call charout ,'Goodbye, World!'


=={{header|Ruby}}==
print "Goodbye, World!"

=={{header|Salmon}}==
print("Goodbye, World!");

=={{header|Scala}}==
[[Category:Scala Implementations]]
{{libheader|scala}}
===Ad hoc REPL solution===
Ad hoc solution as [http://en.wikipedia.org/wiki/Read%E2%80%93eval%E2%80%93print_loop REPL] script. Type this in a REPL session:
print("Goodbye, World!")
=={{header|Scheme}}==
(display "Goodbye, World!")

=={{header|Seed7}}==
$ include "seed7_05.s7i";

const proc: main is func
begin
write("Goodbye, World!");
end func;


=={{header|Standard ML}}==
print "Goodbye, World!"

=={{header|Tcl}}==
puts -nonewline "Goodbye, World!"

=={{header|TUSCRIPT}}==

$$ MODE TUSCRIPT
PRINT "Goodbye, World!"

Output:

Goodbye, World!


=={{header|TXR}}==
{{incorrect|TXR|output isn't consistent with the task's requirements: wording, capitalization.}}
Possible using access to standard output stream via TXR Lisp:
$txr -c '@(do (format t "Hello, world!"))'
Hello, world!$


=={{header|UNIX Shell}}==
The ''echo'' command is not portable, and echo -n is not guaranteed to prevent a newline from occuring. With the original [[Bourne Shell]], echo -n "Goodbye, World!" prints -n Goodbye, World! with a newline. So use a ''printf'' instead.

{{works with|Bourne Shell}}

printf "Goodbye, World!" # This works. There is no newline.
printf %s "-hyphens and % signs" # Use %s with arbitrary strings.


Unfortunately, older systems where you have to rely on vanilla Bourne shell may not have a ''printf'' command, either. It's possible that there is no command available to complete the task, but only on very old systems. For the rest, one of these two should work:

echo -n 'Goodbye, World!'
or
echo 'Goodbye, World!\c'

The ''print'' command, from the [[Korn Shell]], would work well, but most shells have no ''print'' command. (With [[pdksh]], ''print'' is slightly faster than ''printf'' because ''print'' runs a built-in command, but ''printf'' forks an external command. With [[ksh93]] and [[zsh]], ''print'' and ''printf'' are both built-in commands.)

{{works with|ksh93}}
{{works with|pdksh}}
{{works with|zsh}}

print -n "Goodbye, World!"
print -nr -- "-hyphens and \backslashes"


==={{header|C Shell}}===
C Shell does support echo -n and omits the newline.

echo -n "Goodbye, World!"
echo -n "-hyphens and \backslashes"


=={{header|Web 68}}==
{{incorrect|Web 68|output isn't consistent with the task's requirements: wording, punctuation.}}
Use the command 'tang -V hello.w68', then 'chmod +x hello.a68', then './hello.a68'

@ @a@=#!/usr/bin/a68g -nowarn@>@\BEGIN print("Hello World") END

=={{header|XPL0}}==
code Text=12;
Text(0, "Goodbye, World!")


=={{header|ZX Spectrum Basic}}==
10 REM The trailing semicolon prevents a newline
20 PRINT "Goodbye, World!";

{{omit from|PHP|lack of special newline command}}